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مرحباً بك في هذا الكتاب الذي يشكل مقدمة شاملة إلي برمجة الفيجوال بيسك دوت نت بأستعمال البرنامج 
البرنامج مايكروسوفت فيجوال بيسك ٠٠٠٠١‏ . 
لقد صممت هذا الكتاب التعليمي مع الأخذ في الأعتبار مجموعة متنوعة من مستويات المهارات و الموضوعات 
المتنوعة . والنتيجة هي أن المبرمجين الجدد يستطيعون ان يتعلموا أساسيات البرامج في سياق برامج حقيقية و 
مفيدة » و يستطيع مبرمجوا الفيجوال بيسك ٠‏ الخبراء أجادة بسرعة أدوات وأذا كنت مبدئ في عالم البرمجة فتكون 


ما يكمل هذا الأسلوب الشامل هو بنية الكتاب > فصول و ملحقين منظمين حسب الموضوع › و بإستعمال 
هذا الكتاب » سنتعلم بسرعة كيفية أنشاء برامج الفيجوال بيسك ٠٠٠٠١‏ ذات نوعية متطورة و برامج قواعد البيانات 
و تطبيقات الويندوز. ----------- أن جميع الملفات مفتوحة المصدر والبرامج معلومية المصدر وغير مخصصه للبيع 
مع العلم أن الكتاب محتوي الكترونى على الأنترنت ليعم الخير والفائدة علي الجميع. 


ما هو الفيجوال بيسك ؟ 


البيسك 8۸51٥‏ وهي أختآضصlر Beginners All-Purpose Symbolic Instruction Code‏ في عام ۱۹٦١‏ قدمھا 
ohn Kemeny and rhomas Kurtz‏ في الولايات المتحدة الامريكية علي اساس انها لغو بسيطة يسهل تعلمها › 
كما تسمح بالتخاطب مع الحاسب اثناء تنفيذ البرنامج و المشاركة في أستغلال وقته ومااةS۸‏ م۳٠٣‏ › كما يسهل في 
هذه اللغة عمل اى تعديلات او أضافات على البرنامج. 

وسرعان ما أنتشرت هذه اللغة ولم تصبح من اللغات الأساسية للحاسب الالكتروني فحسب بل أصبحت اللغة الاساسية 
في الحاسبات الابكترونية الصغيرة وجزاءاً رئيسياً من تكوينها كما هو الحال في أحدى صورها التى تعرف باسم 
NSBASIC‏ » التي قامت بوضعھا شرکة 0وهrء‌Ni.‏ ' 

حينما أصدرت (ميكروسوفت) أول نسخة من لغة Bai‏ اھں‌وا۷ عام ۱۹۹۱ء لم يكن في حسبانها أنها ستكتسب كل 
هذه الشهرة وستحفق كل هذه الشعبية! 

إن لغة 6۸51٥‏ القديمة نَعَذ من أسهل لغات البرمجة › ولكنها لم تستطع الصمود في المنافسة مع لغات البرمجة 
الأخري بسبب قدراتها المحدودة. 

كان ذلك كذلك» حثي أصدرت (ميكروسوفت) إصدارات ۷B‏ المتتابعة › لتنتقل لغة 8۸51٥‏ من قفار الدوس المجدبة 
إلي مراعي الويندوز الخصبة › مانحة للمبرمج القدرة علي إنشاء برامج ذات واجهة مرئيّة» بأسهل طريقة وفي أسرع 
وقت. 

ومنذئذٍ ولغة ۷8 تتصدر قائمة مبيعات لغات البرمجة › لتدخل في بناء التطبيقات التجاريّة وتطبيقات قواعد البيانات 
البسيطة» وبرامج الوسائط المتعددة aاdم‏ 1ا اں والكثير من الألعاب. 

ولكن للأسف ..دائما وأبدا كانت ۷8 أدني من باقي لغات البرمجة» فتطبيقائها أبطأً نسبيًا وأكبر حجماء وتعاني من 
بعض أوجه القصور في الأداء. 

ولقد استمرت (ميكروسوفت) في تطویر ۷8 عبر ست إصدارات مختلفة » وفي كل إصدار جديدٍ كانت تعالج بعض 
المشاكل القديمة وتضيف المزيد من القدرات» لتضيق الفجوة شينًا فشيئا بين ۷8 وباقي لغات البرمجة. 

ثم أخيرا أقدمت (ميكروسوفت) علي الخطوة التي طال انتظارها.. أصدرت نسخة جديدة بكل المقاييس من ۷6B‏ » بنتها 
من جذورها ۸اهمء ۴۲٠۳‏ لتجعلها نذا حقيقيًا ل ۷٥++‏ › بحيث يمكنك أن تقول بثقة : إن العصر الذهبي ل ۷٥++‏ 
آخذ في الأفول بلا رجعةء حيث سينحصر استخدامها في تصميم المحرّكات و٠"اومع‏ التي تدخل في بناء تطبيقات 
أخري» أو في كتابة الأكود البرمجي الذي يتيح للكمبيوتر التحكم في آلأت أخري › ولكن استخدامها سيتراجع بلا شك 
في تطبيقات الإنترنت والتطبيقات التجاريّة وتطبيقات قواعد البيانات والوسائط المتعذدة ومعظم الألعاب وما شابه › 
نظرا لصعوبتها وتعقيدها وطول الوقت اللازم للبرمجة بها ! ” 

وأعتقذ أن هذا هو السبب الذي دفع (ميكروسوفت) لأصدار اللغة الجديدة 6# › التي تُعتبر تواما ل ۷8 إلا إنها تستخدم 
قواعد ++ في كتابة الأوامر» مما یشگل لمبرمجي ۷٥++‏ إغراء تصعب مقاومته للأنتقال إليها. 

ولكن مهما كانت سهولة ٥#‏ › فان ۷8 يصرعها في هذا المضمارء فهو أقرب ما يكون للغة الأنجليزية العاديّة › ولا 
يحتوي علي الرموز الكثيرة المملة التي تملا ++ › مثل ; » ++ == ٠‏ .... || إلي آخر هذه الرموز التي تجعل 
احتمالات الخطا عند كتابة الكود البرمجي أعلي › وتجعل البرنامج أصعب فهمًا وأقل ألفة عند قراءته. 


أ - د/جمال عبد العظيم : البرمجة الهيكلية المتقدمة > ص١٠‏ . 
- أندروفوس » ترجمة م/ محمد علي يوسف : مقدمة في الفيجوال بيسك دوت نت ٠٠٠٠١‏ > الطبعة الاولي ٠٠٠٠‏ » عاأ۴ PDF‏ .› ص“ 
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مصطلح فيحوال بيسك من ويكيبيدياء الموسوعة الحرة :' 


بيسك المرئي (بالإنجليزية: 86۸51٥‏ اهںءا۷) (أو فيجوال بيسك) هى بيئة تطوير و لغة برمجة من مايكروسوفت تستند إلى لغة 
البيسك الشهيرة. و هى تصنف ضمن لغات البرمجة الشيئية. منذ أن بدأت مايكروسوفت في اصدار الفيجوال بيسك و هى تلاقى 
نجاحا باهرا و شعبية لا بأس بها بين المبرمجين نظرا لسهولتها الشديدة في مقابل التعقيد الشديد الذى يواجهه أى مبرمج 
يسعى لبرمجة ويندوز باستخدام السى أو السى++. الا أن الفيجوال بيسك ربما تكون هى من أسو اللغات التى تكتب عليها 
برامج الويندوز الآن طبعا بعد الجافا.عموما تناسب الفيجوال بيسك تطبيقات قواعد بيانات و التطبيقات المخصصة للشركات 
الصغيرة و برامج الحسابات و هى مريحة و سهلة و تؤدى الغرض بالاضافة إلى أنها تسمح للمبرمج بالتركيز على حل 
المشكلة فغالبا ما لا يواجه صعوبات فنية أثناء كتابة برنامج بالفيجوال بيسك. و لكن بقى أن نذكر أن برامج الفيجوال بيسك لا 
تتم ترجمتها كاملة إلى لغة الألة مثل السى++ أو الدلفى و انما تتر جم إلى كود وسطى يتصل مع مكتبة ربط تسمى ب" Run‏ 
"rime i‏ و اسمھا ااچ.NSVBMnn‏ مع ملاحظة أن حرفی ال يشيران إلى رقم الاصدارة. 


لغة البرمجة فيجوال بيسك هي لغة ذات تصميم مرئي واجهة رسومية بعكس بعض اللغات مثل الاسمبلي ذات الشاشة السوداء 
حيث تحتوي هذه اللغة على العديد من الاوامر بداخلها ولغة سهلة التطبيق تم تطوير هذه النسخة من البرنامج عن النسخة 
القديمة ءاوجط و التي تعمل تحت تحت بيئة وه إلى هذه النسخة التي تعمل تحت بيئة وندوز . تعتمد اللغة في تطوير تطبيقاتها على 
الكائنات فهي تشبه العديد من لغات البرمجة الحديثة من حيث اعتمادها على الديناميكية و الاحداث. تعني الديناميكية في هذه 
اللغة القدرة على استدعاء اي اقتران او اجراء اعتمادا على الحدث. الحدث هو اي عملية يقوم بها مستخدم التطبيق على 
التطبيق مثل الضغط بزر الفارة او الضغط على أحد ازرار لوحة المفاتيح او حتى تحميل نموذج. لتعلم اللغة يفترض بك اتقان 
التالى 


مميزات الفيحوال بيسك 


٠ه‏ لغة سهلة و سريعة لانشاء تطبيقات ويندوز. 

ه٠‏ تدعم البرمجة الشيئية الا أن ذلك ليس بشكل كامل. 

ه٠‏ تجربة برامج الفيجوال بيسك سهلة و سريعة لاعتمادها على مكتبة الربط خلال و قت التشغيل. 
ه تعتبر لغة الفيجوال بيسك لغة كائنية المنحنى 

ه سهلة التعلم والفهم 

ه سهولة اكتشاف الاخطاء فيها 


Visual Basic 1 


الاصدار الاول من ءاود اهںءا۷ كان محدود للغاية. ولم يكن موجه لتطوير التطبيقات الحقيقة لبيئنة sسملہ۷.‏ مع انه كان 
سهل الاستخدام ذو واجهة رسومية ولغة برمجة مرئية إلى انه كان يعتبر كلعبة مسلية للمبرمجين. 

Visual Basic 2 

الإصدار الثاني من اوج6 امںءا۷ لم يظهر اي جديد باستثناء اضافة القليل من الخصائص ودعم أفضل لبيئة التطوير المتكاملة 


.IDE‏ لكن في تلك الفترة» ظهر مولود جديد وهو النظام 0 Ùك5٠٥٠٠۸‏ لقواعد البيانات العلائقية وكان كل تركيز شركة 
اMicrosot‏ هو الدمج بینهما. 


Visual Basic 3 


يعتبر الإصدار الثالث هو بداية طريق النجومية او الشهرة ل ءأوجB‏ امںءآ۷! حيث قدم دعم لقواعد البيانات واصبح ذو نهاية 
مفتوحة بفضل الاضافات التي كنت تسطيع دمجها مثل ×۷6 والتي تطورت فيما بعد إلى .0٥×‏ ظهرت الكثير من التحسينات 


أ - موسوعة ويكبيديا ألم أ)أس : مصطلح الفيجوال بيسك نصياً كما جاء فيها 


http://ar.wıkipedia.org/wık1/oD9%81%DI9%SA%DSACFDI%SSTDSTA17D9%84 FGDSCASDISADSB 
3%D9%83 , Viewed 27/1/2009 
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في بيئة التطوير المتكاملة 2۴| وهاجر مئات ان لم يكن الاف المبرمجين إلى ءiوجع‏ امںء۷. وبدأت تلك اللغة كمنافس ضعيف 
لتطوير البرامج الحقيقية او التجارية لانه كان ما زال ينقصها المزيد. 


Visual Basic 4 


كان الهدف الاساسي من الاصدار الرابع هو مرحلة انتقالية إلى 95 sسهمهلہا۷‏ او ان صح التعبير» القابلية لتطوير تطبيقات من 
نوع ۳۲ 1اط. وكان أول اصدار من اصدارات اعںءا۷ ءاوه تولد شيفرة للعمل تحت معالجات من نوع 81]۳۲. ليس هذا فقطا 
بل اضاف الاصدار الرابع امكانية لانشاء مكتبات من نوع اا ×ءء)ء۸ والتي زادت في اسهم شهرة امںuءا۷‏ ٥iوج8‏ حتى 
اصبح معترف كلغة برمجة لانشاء تطبيقات حقيقية حيث اضاف الميزة التي انتظرها المبرمجون وهي البرمجة كائنية التوجه 
00۴P‏ لکنھا كانت محدودة بسبب استطاعتك بانشاء الففغات ووجاإع فقط دون اي امكانية اضافية كتعدد الواجهات 
„Inheritance Aڎlرgll yl Polymorphism‏ 


Visual Basic 5 


الاإصدار الخامس كان بمثابة الاعلان الرسمي في ان لغ اوج6 امںء۷ هي لغة برمجة لتطوير التطبيقات الحقيقية والتجارية. 
حيث اضاف العديد من انواع المشاریع ک ActiveX Controls‏ و ActiveX Documents‏ وغیرھا.. واضافة مزایا عدیدة 
للتحكم بشيفرة ملف ال ع×E‏ الذي يخيرك من تحويل الشيفرة المصدرية إلى ملهء-P‏ او مdه٥-مivاج.‏ بالاضافة إلى 
التحسن الحقيقي لبيئة التطوير المتكاملة |2٤‏ والدعم الاضافي لقواعد البيانات. 


Visual Basic 6 


الاإصدار السادس لا يختلف عن الاصدار الخامس كثيرا لكن هناك العدید من التحسینات وعلاج للشوائب ووںع التي كانت 
موجودة في الإصدار الخامس. من أهم الاضافات في الاصدار السادس هي الزيد في ادوات قواعد البيانات والمبنية على ۸50. 
كذلك تحسن واضح في ادوات التحكم. وهناك العديد من التطوير في لغة البرمجة كدعم انواع البيانات المعرفة من قبل 
المستخدم 507ل والزيد من الدوال وہهااءہں۴. واضافة المزيد من الويزارد وله¡ ودعم لتطبيقات انترنت 1٥۲ها|.‏ 
والكثير والكثير من التحسينات. واخيرا 


Visual Basic.NET 
تم انتاج هذا الإصدار مع تغییر جذري عما سبقة من الاصدارات ولقد صدر ف ضل هذة التقنية ثلاثة اصدارات إلى الان‎ 


vb 2008 ùًڵly‎ vb2005<Vb 2003 
Visual Basic تقديم‎ 


Basi‏ اهuء۷i‏ اداة قوية وفعالة لتطوير تطبيقات متوافقة مع بيئة sسهملہ1.‏ يوفر لك بيئة تطوير متكاملة سهلة الاستخدام 
لانشاء الحلول سواء كانت شخصية او تجارية في وقت قياسي عن طريق فلسفة البرمجة المرئية. حيث تصمم الشاشات 
ونوافذ برنامجك عن طريق نقرات وتحريكات خفيفة بالفأرة كأنك ترسم مربعات ودوائر باستخدام برامج رسم وغيرها. 


Basic‏ اisua‏ لیس کما کان 


لعلك سمعت كثيرا عن لغة ال 6۸51٥‏ وقد تجنب تعلمها بسبب حدودها التي تقصر امكانياتها كسائر لغات البرمجة. لكن مع 
الاصدارات الحديثة من ءاوح امںوءز۷ فان الامر اختلف! فالان اصبحت امكانيات اللغة بلا حدود. وقابلية التطوير لا نهائية اي 
انه اصبح ذو نهاية مفتوحة. فعن طريق الاضافات وہ!-لك۸ وادوات التحكم الخارجية اهإ اه٤‏ ×مAc†iv‏ ومكونات °00 
بصفة عامة › تستطيع انجاز كل ما استطعت انجازه باللغات المختلفة. فلاضافة مكون C0١‏ جديد لا يتطلب الامر منك سوى 
تحديد اسم وملف المكون ومن ثم استخدامه مباشرة!حقيقى أصبحت أكثر تطور. 
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i1۹40 ۷WS التوافقية مع‎ 


التطبيقات التي تنشئها بواسطة اوج8 اهںوءا۷ متوافقة %٠٠١‏ مع اصدارات sسملمآ۷‏ المختلفة. فالنواة الداخلية 
للتطبيقات المنشئة بواسطة ٥وج6‏ امںءا۷ هي عبارة عن سيل من اجراءات ۸۲١‏ التي عبارة عن روح نظام sس0لہاW.‏ اما 
عن الدوال الاضافية التي توفرها لغة البرمجة فهي موجودة في مكتبة مستقلة 501-1 5۷/8۷١160.‏ وهي المسؤولة عن تشغيل 
برامجك التي طورتها عن طريق اوج اهuوءا۷.‏ 


حلول الانترنت 


ء¡Bs‏ اهuء۷i‏ يوفر لك العديد من الحلول والخاصة بالانترنت. فيمكنك من انشاء ادوات تحکم ءsاہ C٥٣٤٣‏ ×٥۷آاA‏ يتم 
تنفيذها في صفحة ويب. او تصميم تطبیقات متقدمA‏ ک— ActiveX Documents‏ للعمل على متصiح .Internet Explorer‏ 
المزيد ايضاء اوج6 اجںوءا۷ يوفر لك بيئة تطوير خاصة لتطویر تطبیقات انترنت سواء کانت للعمیل ۲٥ا٥‏ کتطویر تطبیقات 
من نوع HTML Applications‏ او للخادم Server‏ کتطویر ت¦طبيقlٽ „Applications ASP‏ 


Visual BaSİC zg مستقىلك‎ 


حقق ءاوه8 اهںءا۷ شعبية لا مثيل لها بين مطوروا التطبيقات تحت بيئة sسwهمهلم۷1.‏ والفرص الوظيفية لمبرمجي اإمuءا۷‏ 
si‏ هي الاعلى. كذلك» المواقع التي تناقش هذه اللغة في زيادة اسية! واعداد المبرمجون المهاجرون إلى ءiئج8‏ امuءذ۷‏ 
يومي الزيادة. المزيد ايضا › ادوات التطوير الخاصة ب اوج8 امںء۷ كمكونات C00‏ في كل مكان ويكفيك وجود أكثر من 
ثلاث مجلات عالمية تناقش هذه اللغةً!! وهذا .اوم8 امuء۷‏ قرب ان تبصر اصدارته النهائية النور» والتي بدورها 
طريقك إلى محاذاة الركب وتطوير تطبيقات انترنت الذكية. 


عيوب الفيجوال بيسك 


ه٠‏ عدم مجانية برامجها › أي أنك تحتاج غالبا للدفع للحصول على ملفات مفتوحة المصدر 

ه٠‏ لايتم ترجمتها بشكل كامل إلى لغة الألة. 

ه٠‏ لا تدعم كافة أشكال البرمجة الشيئية. 

ه المترجم نفسه به بعض الشوائب و التى تظهر في البرنامج المكتوب حتى في حالة خلو البرنامج المصدر من 


الأخطاء. 
تاريخ الفيجوال بيسك' 


أنتجت شركة مايكروسوفت أول إصدار من لغة البيسك عام ۱۹۷۰م » وسمي اوج8 والأسم يعتبر اختصار للكلمة للغة 
البرمجة العامة التسلسلية للمبتدئين ) Code Beginner”s AII-Purpose‏ nstructionا‏ icاboصSy)‏ › وتوالت الإصدارات 
فظهر الإصدارات ٠ Quick Basic and QBasic ›6 W-8 AS|°‏ و كلهم يعملون في بيئة ءم » و مع انتشار بيئة ويندوز 
ظهرت فيجوال بيسك التي احتوت علي كثير من أوامر 48۸51٥‏ وأضافت العديد من الوظائف التي جعلت من البرمجة بفيجوال 
بيسك يسره و سهلة . هناك الاآلاف من المواقع التعليمية للفيجوال بيسك و من Visual Basic Tutorials‏ 


في عام ۱۹۹١‏ تم افتتاح أول موقع عربي على الإنترنت يهتم بلغة فيجوال بيسك وهو /http://www.vb4arab.com‏ 


في عام ۲٠٠٠١‏ قامت مايكروسوفت بإنتاج النسخة المطورة BAS1٥.٤‏ ا۸ل5] والتي تعتمد على البرمجة الشيئية. 


| - موسوعة ويكبيديا aأل١عم‏ اأ : معلومات عن الفيجوال بيسك نصا من الموقع 


http://ar.wikipedia.org/wik1/%D9%81%eD9%SAFGDSACTGDI%SSTDSA1D9%84 FGDSTASTGDISATGDSB 
3%D9%83 , Viewed 27/1/2009 
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ما الحدید الفیحوال بیسك دوت ات 


إن التطويرات التي لحقت ب ۷8.۸61 من الكثرة بحيث لن نستطيع أن نحيط بها كلها هنا.. ولكن يكفي أن نذكر منها ما يلي: 


لم تعد ل ۷B‏ واجهة استخدام مستقلة» فكل لغات ا6 تستخدم واجهة واحدة» مليئة بالأدوات التي ٹسهل بطريقة 
مدهشة عمليّة تصميم البرنامج.. إن هذه الميزة تسمح لك بإنشاء تطبيقات تدخل فيها أكثر من لغة برمجةء دون أن 
تحتاج لفتح أكثر من واجهة.. إنها واجهة واحدة فقط لكل المبرمجين. 

هناك إمكانيات جديدة في نافذة محرر الأكود البرمجي» منها قيام اللغة بكتابة جملة نهاية المقطع تلقائياء بمجرد كتابتك 
لبدایته وضغط زر ..6۲"ع فمثلا: لو كتبت جملة۔ 


If X = 0 Then 
فان محرر الأكود البرمجي سيضيف الجملة التالية تلقائيًا:‎ 
End If 


بل إنك لو لم تكتب كلمة ۲٥٢‏ فسيكتبها لك محرر الأكود البرمجي تلقائيا ! 

هذا بالأضافة الي أنه سيصع مشر الكتابة داخل مقطع ۴| › وسيقوم بتنسيق المسافات البادئة تلقائياء بحيث يبدو الأكود 
البرمجي منظما وواضحا عند قراءته. 

كما أن هناك تحسينات كثيرة في تلميحات الشاشة التي تعرض قيم المتغيّرات وأنواعها ومعاملات الأجراءات والدوال 
وقيمَها المعادة» مع نبذة عن وظيفة كل دالة وكل معامل.. باختصار: لقد أصبحت كتابة الأكود البرمجي متعة. 


هناك تحسینات کثیره في مظهر النموذج والأدوات» وهناك العديد من الخصائص والوسائل الجديدة التي تمت إضافتها 
لهذه العناصرب بحيث تمنحك تحگما آکبر فیھا.. فمثلاء eee‏ 
تحديد المنطقة التي ستظهر منه علي الشاشةء بحيث يمكنك تصميم نماذج باي شكل .. ولم تعد مضطرا لكتابة الأكود 
البرمجي الذي يحافظ علي تناسب مقاييس الأدوات مع مقاييس النموذج كلما تغير حجم النموذج» فقد صارت هناك 
خصائص جاهزة مسئولة عن هذا.. هذا بخلأف العديد من الأدوات الجديدة › مثل الفاصل ١٠]]ام5‏ الذي يمكنك من تغيير 
حجم الأدوات المتجأورة أثناء تشغيل البرنامج. 


صار بامكانك إضافة الأزرار والأدوات للنماذج کی وقت التنفيذ Run Tine‏ > مع قدرتك علي ربطها بأي اجراء لیتم 
استدعاوه عند ضغطها. 


لم يعد هناك أي قصور في مترجم الأكود البرمجي مام Co»‏ › > فكل لغات N٥‏ .5 تعمل علي مترجم واحد» مما يعني 
أن VB‏ ةد صار بفوة وسرعة وكفاءة ...+ ۷٥+‏ وکمثال› صار بامكانك استخدام البرمجة الأرتدادية Recursive‏ 
Programming‏ دون أن تخشي من بطنها أو استھلاکها أحجم الذاكرة» فقد صارت د منتهي السرعة والكفاءة. 
أصبح بإمكانك معالجة الأخطاء» عن طريق استخدام معالجات الأستثناءات ersاnd Exception H2‏ في جملة ٣y..‏ 
Catch.. End Try.‏ 

مبنيّة بالكامل علي مفهوم البرمجة بالكائنات وہ¡ص ^ Object Oriented ۴٥g‏ › لدرجة أن الأعداد 
الصحيحة ءإموم]"!| والنصوص Strings‏ والمصفوفات وره۸۲۲ قد صارت خلايا ومءءهاع › وصارت لهذه العناصر 
خصائضص ووسائل جاهزة.. فمثلاء أصبحت لديك وسائل جاهزة تنتمى للمتغير النصي»› تسمح لك بالبحث فيه أو تقطيعه 
أو استبدال أجزاء منه... إلخ... كما صارت لديك وسائل جاهزة لعكس المصفوفة وترتيبها والبحث فيها! 


صار بامكانك استخدام کل مفاهیم الوراثة مہ هاام۲ہ! وتعدد الأشکال ہواطم۲ه"راهم بلا أي مشاکل ..وإن کان 
مسموحا لك بوراثة خليّة واحدة فقط مء هاامطم! ماوہاك للتسهيل. 

يمنحك إطار العمل ok‏ سمصه۴ .٥1‏ ثروة هائلة من الخلايا وءمءءهاع › تقذر ب ٠٠٠٠١‏ خليةء تفعل كل ما تحلم به 
وأكثر» بحيث تريحك بدرجة كبيرة من الأحتياج لاستخدام دوال ۸۴١‏ الخاصة بالويندوز» بما فيها من تعقيد ومشاكل .. 
وأحدث ما فعلته (ميكروسوفت)» هو إصدار نسخة جديدة من ×1ءمءا مبنيّة بالكامل بالخلايا بدلا من. وا۸۴ 

هذا بخلأف أن معظم هذه الخلايا قابل للوراثةء بما فيها الأدوات وامء)هC‏ نفسهاء مما يمنحك القدرة علي تطوير 
أدائها بما يناسبك . 


ومن الخلايا الجاهزة العديدة التي يمكنك استخدامها « الخلايا اlتıllة BitArray - Queue -: Stack‏ « ي ArrayList‏ 
وغیرها. 


أ - الأفاق موقع المنتدي : تعلم اساسيات البرمجة في الفجول بيسك دوت نت › تاريخ ٠٠٠۸/۹/١١‏ . 


http://www.montada.com/forumdisplay.php?f=212 
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أصبح بامكانك تعريف المتغيرات داخل مقاطع الجمل الشرطْيَةَ وام" هاهS‏ ۴| والجمل التكرارية ممه ] › بحيث تكون 
معزولة عن المتغيرات الموجودة خارج هذه المقاطع. 


١‏ بل أصبح بإمكانك تعريف الخلايا داخل الخلايا sمءءها٤‏ إم†ومN‏ » وأي نوع مما داخل أي نوع آخر. 
أصبح بإمكانك تعريف الواجهات وهءه؟ءه]"| وكتابة الخلايا التي تطبُقها وتنفذها. 


j‏ أصبح بامكانك استخدام المندوب Delegate‏ کمعامل للأجراءات والدوال»› بحيث يمكنك تمریر اسم أي إجراء أو دالة 
کمعامل ! 


و أصبح بإمكانك استخدام السمات s٥ا‏ ما1۲ في تعريف الخلايا والوسائل والخصائص والأنواع المختلفة › مما يختصر 
لك الكثير من العمل » ويمنحك العديد من القدرات. 


۵ لديك إمكانيات جديدة وعديدة تمنحها لك خلايا جاهزة › للتعامل مع الملقات والمجلدات.. وعلي سبيل المثال › يمكنك أن 
تراقب أي تغییر يطراً علي ملفات المجلد الذي ترید › باستخدام الأداة FileSystem Watcher‏ > كما يمكنك أن تخزن 
كائنا أو مصفوفة أو مجموعة «هiاءماامع‏ من أي نوع إلي ملف مرة واحدة › وإعادة قراءتها حينما تريد › باستخدام 
خلايا اudأأİأؤSerializationû.‏ 


١‏ هناك إمكانيّات هائلة في مجال الرسم والتلوين تمنحها لك مكتبة ..+ا0 يكفي أن تعرف أن بإمكانك الأن رسم منحنيات 
معقدة » وتكوين أشكال مركبة من مجموعة خطوط ومضلعات ومنحنيات › وتلوين السطوح بألوان متدرجة › وتحديد 
شكل مساحة الرسم › وتحديد درجة الشفافية › وتدوير الرسوم وتغيير مقاييسها تكبيرا أو تصغيرا.... إلخ. 


يمكنك استخدام المؤشرات sإم†Poi‏ د بعض الأحيان › للقراءة والكتابة کی الذاكرة » كما يمكنك أداء عمليات معقدة 
علي النظام ورك لم تكن لتحلم بها ! 


j‏ أصبح بامكانك تقسيم برنامجك لمجموعة من العمليات المستفَلّة sل‏ 1|2 ¢ مما يعني أن برنامجك يستطيع القيام بأکثر 
من عمليّة في نفس اأئحړظة Multithreading‏ . 


هناك إمكانيات جديدة رائعة للتعامل مع قواعد البياناتء تمنحها لك تقنية ا٥١.۸50‏ › بالأضافة للعديد من الأدوات 
المرئيّة التي تساعدك في انشاء تطبيقات قواعد البيانات بأقل قدر من الأكود البرمجي. 


١‏ أمًا الجديد تماما » فهو قدرتك علي تصميم صفحات الإنترنت بنفس الطريقة التي تصمَم بها النماذج العادية › مع كتابة 
الكود البرمجي ۷8 بمعظم إمكانيّاته › لأنشاء تطبيقات ۸5٥‏ تعمل علي الخوادم مه5 بدون كتابة حرف واحد من 
لغ ASP‏ !! 


إصدارات الفيحوال بيسك دوت نتا 


صدر أول إصدار لفيجوال بيسك .١.٥‏ (مايكروسوفت فيجوال بيسك 2002 ۸6.) في فبراير ۲١٠٠۲‏ و أصبح الأصدار 
الثاني (مايكروسوفت فيجوال بيسك 2003 ).۸٥‏ متوفرأً بشكل واسع في مارس ۲٠٠۳‏ بعد فترة طويلة من التطوير و العمل 
الجماعي › أصدرت مايكروسوفت فيجوال بيسك ۰.0 في أواخر العام ۰0 لقد أصبح فيجوال بيسك ۰.۰0 مندمجاً الأن 
بشكل محكم مع الفيجوال ستديو لدرجة أنه يوفر فقط كمكون في طقم البرمجة فيجوال بيسك ۲٠٠١‏ » الذي يتضمن مصرفات 
لفيجوال #© و فيجوال ++ و الفيجوال #ل والأدوات تطوير مايكروسوفت .١.٥٠‏ والأخري لكن فيجوال ستديو ۲٠٠٠١‏ يباع في 
عدة نكأوين منتج مختلفة › من بينها الطبعة لمل ها و النسخة اههاووم]هإم و النسخة م†اں؟S‏ "هه٠۲‏ و النسخة 
»ع . و هناك عدد محددود بين الفروق في النسخ السابقة و أنا انصحك بأستخدام برنامج 2005 ۷8.۸6 صدار جديد 
.Visual Basic .Net 2008‏ 


ع ماگل فافرسرن» درخ مرك امرب رارع دار افر ل الخال بسك درت نك ٠٠٠١‏ * ت خطرة بخقرة ٠"‏ اة الى 


۰1 ۰ ص۱۹ 
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متطلسىات اللظام: 


ستحتاج إلي الأجهزة والبرامج التالية لتحميل البرنامج 2005 ۷8.۸6 علي الكمبيوترك الشخصي: 


أستخدام أنظمة التشغيل التالية. 


Windows XP Professional serves Pack 2 
Windows XP Home Educat serves Pack 2 
Windows server 2003 serves Pack 1 
Windows server 2000 serves Pack 4 
Windows Data center server 


معالج بنتیوم ٠۰۰‏ میجاهرتز أو متوافق و سرعه ۱ ميجا هرتز. 

٦‏ ميجا بايت ذاكرة و يفضل أن يكون أعلي. 

محرك أقراص مضغوطة أو رقمية. 

شاشة (ذات دقة ۸٠٠*٠٠‏ ) أو أعلي مع ألوان ٠٠١٠‏ لوناً و يفضل أستخدام ( )۷٠۸ * ٠٠١٠٠١‏ ألوان عالية ۲ بت. 


موقع تكنولوجيا التعليم 


ندعوك لزيارة موقع تكنولوجيا التعليم علي الإنترنت علي العنوان 1 

salem 4 1C E O FEE 
ستجد هناك شروحات عن كل كتبنا ومشاريعنا العملية › كما يتضمن موقع تكنولوجيا سما‎ 
www.salem4lt.com › التعليم شروحات عن برامج المحاكاة ثنائية الأبعاد › ثلأئثية الأبعاد » معالجة الصور‎ 
› لصفحات الإنترنت › الويب › المنتديات الترفيهية‎ ١ أكمبيوتر › د تصميم‎ ١ البرمجة › الشبكات › الإنترنت › مبادئ‎ 
المنتديات الخاصة بكلية التربية النوعية ببورسعيد و‎ 


الأسئلة و التعليقات 


إذا كانت لديك أي تعليقات أو أسئلة أو أفكار تتعلق بهذا الكتاب أو الملفات التمارين أو الفيديوات علي الأسطوانة 
المرفقه معه . الرجاء أرسالها علي 
الیرید الا لکترونی ان -عE‏ منندی على الوب eb Sie‏ 
Mohamed youssef 1 988@yahoo.com‏ 
www.salem4it.com Portsaid 2010@myahoo.com‏ 


Mohamed.yoyo@qmail.com 


د ماگل هارن »رة مرك القرت رارم دار اتر الى : افيجوال بك دزت نت د٠٠٠‏ ”ت خطرة بكطرة ,اة اللي 


ك 


Prog: Mohamed Youssef ۱١ E_Mail: Mohamed.yoyo@gmail.com 


الأهراف 


فى نهاية دراسة هذا الكتاب » يحب أن يكون الدارس قادرا على: 


-١‏ كيفية تنبيت الفيجوال بيسك ۲٠٠١‏ بكفاءة على حاسبك الشخصي. 
۲ - تشغیل برنامج مایکروسوفت الفیجوال ستیدیو .۲٠۰٠۵‏ 

۴- أستعمال بيئة تطوير الفيجوال ستيديو المندجة. 

.٠٠٠٠١ قيام فتح وتشغيل برنامج الميكروسوفت الفيجوال بيسك دوت نت‎ - ٤ 
ه- تغيير إعدادت الخصائص المشروع.‎ 

٠‏ - نقل أطر الأدوات وتغيير حجمها وأخفائها تلقائيا. 

۷- كيفية أستعمال المصفوفات ضمن البرنامج. 

۸- خصيص إعدادت بنية التطوير المطابقة بالتعليمات. 

.٠٠٠١ قيام بحفظ تغيرات » أماء التعامل مع الفيجوال بيسك دوت نت‎ -٩۹ 
التدريب علي كتابة البرامج وتصميم الواجهة النموذج.‎ -٠ 

. التعرف علي جميع قوائم البرنامج‎ -١ 

۲ - قيام بفتح و أنشاء مشروع جديد في بنية الدوت نت. 

۳ - التعرف علي المغيرات والنوابت والتركيبات. 

-٤‏ شرح التعامل مع مكتبة ۸(0.[N6)‏ وربطها بقواعد البيانات. 

٠١‏ - الحصول علي مصطلحات والأكواد بصورة سريعة بالغة العربية. 

.A۸D0.Ne) التعرف علي لغة ]584 . لاستخدام ها مع‎ - ٠١ 

۷ - كيفية عمل التقارير ۸001۲۲5 بصورة صحيحة. 

۸ - التعامل مع انشاء المشاريع البسيطة والوصول إل البرامج المتطورة. 
۹- التعرف علي جميع الأدوات الخاصة والمميزة للفيجوال بيسك .٠٠٠٠١‏ 
٠‏ - التعرف علي الدوال والوسائل الموجودة بالبرنامج. 

-١‏ كيفية أنشاء وحذف والتعديل قواعد البيانات والجدأول. 

۲ - أستخدام جميع نوافذ البرنامج للتعامل معها في البرمجة. 

۳ - معرفة تطور البرامج وتقنية الدوت نت الحدينة. 

٤‏ - أستعمال أوامر المساعدة وتخصيص لمساعدة حسب مشكلة معينة. 

٠‏ - الحصول علي المساعدة عن طريق الإنترنت للدعم الفني للبرنامج. 
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مقدمة نی الدوت نت ا.۸. 


مفهوم الدوت نت وفائدتة ومكوناتة وايضاح مفpg4 .Net Framework‏ 


ما هو مفهوم شرکة میکروسوفت ل دوت نت ؟ 


التكنولوجيا الحديثة تتطور وتتغير بسرعة في كل مجالات الحياة وكذلك هو الحال في تكنولوجيا الكمبيوتر وبرمجتة واحيانا 
التكنولوجياالحديثة تكون من الأبداع في مكان تجبرنا فية لتحدي ابسط افتراضياتنا.وفي صناعة الحاسبات» كان اخر 
واعظمابداع هي تكنولوجيا الإنترنت تلك التقنية التي ر أوجة العالم اقتصادياً وثقافياً واثرت العلم في شتي مجالاته ومع 
هكذا تقنيةنجبر لأعادة التفكير كيف ستكون البرامج و كي كيفية تطويرها واستعمالها في ظل هذة التكنولوجيا.رغم ان هذة العملية 
تحتاج للوقت عادتاً وفي ظل مجئ تكنولوجيا قوية كانت أول عقبة هيربط شبكة الإنترنت بمنصة عمل حيوية تعمل خصيصا من 
اجلها وقبل مجئ ميكروسوفت كان المطورين يستخدمون منصات عمل قديمة في ظل الامكانيات الجديدة للأنترنت.وقبل عدة 
سنوات قررت ميكروسوفت ان الوقت قد حان لعمل تقنية جديد من اجل تاسيس عالم مابعد النت النتيجة التي ظهرت ام١‏ وهي 
تمثل نقطة انتقال جذري ف عالم برمجيات ميكروسوفت.اصبحت م٥۸.‏ مسقبل مايكروسوفت الأن فقد اعلنت ان اغلب ابحاثها 
وتطويرانها ستكون علي هذة التقنية.ومن المتوقع بعد فترة ليست بطويلة ان تكون كل منتجات مايكروسوف معمولة علي 
هذااساس ]ه۸ مايكروسوفت الأن اصدرت الأصدار الثاني لها 2.0 ..٤۲‏ ا؟ Micros‏ fه‏ وبيئة التطوير تدعي Sudo‏ امuوVi‏ 
5 واصدار الفيجوال بيسك الجديد يدعي 2005 ءsiج8‏ امuوء۷‏ 


ما ھş .NET‏ ؟ 


میکروسوفت . Ne‏ تقنية واسعة النطاق وطموحة جدا . وهي تشJja .NET Framework‏ التي تشتمل علي اللغات وتنفيذ قواعد 
العمل › بالأضافة الي طبقة واسعة من المكتبات ibrarilesا‏ assاc‏ › وهي غنیه بالمكتبات الداخلية. بالأضافة إلي النواة .NE٣‏ 
Framework.‏ بالأضافة إلي تقديم مستوي متكامل للبرمجيات عبر شبكة الإنترنت . وتقديم خدمات للشبكة بما يعرف ط٥۷‏ 
‰5 وسوف ناتي إلي تفصيل هذا المفهوم بالكامل. 


أهداف ش ركة مایكروسوفت: 


قامت شركة مايكروسوفت بعمل تقنية الدوت نت بتكلفة مليارات الدولارات و تحتوي علي اكثر من ٠١‏ الالاف مكتبة لأنشاء 
العديد من البرامج كتي يتوافق برامج الويندوز علي أنظمة اللينكس . حققت مايكروسوفت في هذة التقنية الكثير من الأهداف 
التي ظلت لفترة تحأول ت تقدیمها بلغة ۷8 اصبحت لغة اشكال بالكامل 00٣‏ وبيئة التطوير بين لغات البرمجة مباشرة تماما حتي 
انة يمكن مزج الشفرات في نفس البرنامج .كما تم مواجهة تحدي كابوس لغة الجافا ۸۷۸ل بلغة سي شارب # ٥C‏ مع معمارية 
اطار العمل )مس مه۴ كما صارت معضلة صعوبة تطوير تطبيقات الشبكة العنكبوتية امر في غاية السهولة بالأضافة 
لأستيعاب تقنيات حديثة مثل 01× وخدمات عبر الشبكة وتم توحيد الكثير من الخطط الخاصة بشبكة في المنتج الذي سيصبح 
محور التوجة القادم للشركة كما اسلفت. 
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تطوير تقنية دوت نت: 


کان ظهور النموذج الأولي لتقنية الدوت نت في مؤتمر المطورين في يوليو ۲ ۰ وعلي اساس انة يتم اصدارها في بداية 
۳ وقد حلت هذة التقنية محل تقنياتعديدة حأولت من خلالها ميكروسوفت ان تلحق موجه الشبكة العالمية للمعلومات مثل 
و ۸۶ الذي حل محلة 5P ..٤۲‏ المحسن .واستدعاءات ۸۲١‏ مثل ۸۲1 و ۴٥‏ بمجموعة متناغمة من فثات موج8 
اع وقد تم التنازل عن تقنية 5۸۸ لصالح التقنية الجديدة2.0 ٥0١0+‏ محل سابقتها وهي مختلفة عن سابقتها كما تم اعادة 
بناء لغة ۷8 لتصبح لغة اشكال كاملة 00۴ وتم استحداث لغة برمجية جديدة تمزجبين سهولة الفيجوال بيسك وقوة ++ ° 
تسمي السي شارب#٥‏ ولتضمن الشركة انتشارها تم جعلها مفتوحû‏ ا)أمaصدرSOURCE OPEN‏ 
ومن المفيد الأشارة انة تم التعلب علي اشكالية تعدد النسخ من المکتبات e ٣s‏ ٬ممصہہC‏ والتنازل عن استخدام مخزن البيانات 
العام رواوهR‏ واستخدام تقنية 01× وتفنية 50۸۴ في عملية تطوير التطبيقاتالخاصة بالشبكة العالمية وخصوصا خدمات 
عبر الشبكة ومءا۷مS‏ ط۷ الواقع ان هذة التقنية حيوية جدا لشركة مايكروسوفت التي تحأول الأنتقالمن توجهها الحالي ببيع 
الوحدات والنسخ إلي تقنية التأجير والخدمة للحفاظ علي مكانتها في المقدمة حيث ان التوجة يعاني من الكثير من الأشكاليات 
كما ان مستوي مبيعاتها يعاني من الضعف والأنخفاض المستمر. 


آهمية تقنية الدوت نت: .×٤٣‏ 


وقد بدات القصة منذ عام ۲۰۰۰ عندما اعلن بيل جيتس في موؤتمر المطورين المحترفين ٥0ع‏ في ولاية فلوريدا ةذ هي الولايات 
المتحدة عن تبني مایکروسوفت للدوت نت (كانت تسمي وقتها الجيل الجديد لخدمات النوافط 

Next Generation Windows Services )‏ كتقنية للألفية الثالثة والتي بدات في الأساس كتطور لمزود البيانات4 |١5‏ وتطور 
لأدوات التطوير ۷87 في عام ٨۸‏ وقد ذکر بیل جیتس ان %۸۰ من مصادر میکروسوفت سوف تنفق في اتجاة دعم هذة 
التقنية الجديدة. وبعد ذلك بثلاث اشهر قامت ميكروسوفت بشراء 135 مليون دولار من الأسهم غير المصوتة من اجل انقاذ 
شركة كورال وذلك لجعل الشركة تقوم بتقديم فكرة الدوت نت إلي نظام اللينكس عن طريقك ورال لينكس وهذا ما حدث فعلا. 


أهمية الشكة الدولية للأنترنت' 


ان انفاق شركة في عالم البرمجيات %۸٠‏ من مواردها في سبيل دعم هذة التقنية لأيعني الأ جديتها وايمانها بقدرة هذة التقنية 


علي التحكم بالمستقبل. 
خصوصاً اذا علمنا ان السيولة المادية الحالية لدي مايكروسوفت اكثر من مجموع اموال اكبر مئة شركة من شركات العالم 
البرمجية معا. 


هذة التقنية الجديدة اساسها الإنترنت والمهم ملاحظة اهمية الإنترنت المتزايد في عالمنا حاليا فقد أوجد لنا حياة جديدة تماما. 
ولقد اثبتت الخبرة في مجال التجارة الألكترونية ان فعالية منتجات الإنترنت تتناسب طردیا مع القدرة علي الأبقاء علي الأتصال 
بالزبائن. أي اننا ملزمين بابقاء رابطة الوصل بينننا وبن زبون موقعنا. 


خدمات عبر الشبكة الدولية (الإنترنت) 


ان عملية تطوير البرامج وتحديثها عملية مهمة لكل منتج برمجي وذلك لما يشهد العالم من احتياجات تتطور تبعا لمتغيرات 
اخري وان مندون الدعم الفني والتحديثات للبرامج من المكن ان يفف المنتج ثقتة عن الزبون عند حاجتة لتحديث ما علي 
برنامجة فلا يجدةممأً يجعلة يبحث عن بديل اخر مناسب ومن هنا تاتي الحاجةإلي مفهوم البرمجیات کخدمlت Sofware‏ 
vie‏ وتقوم بيئة الدوت نت بتقديم هذا المفهوم باستخدام تقنية جديدة تسمى ( سواب ) 

Si صmpاe Object Access Protocol‏ بروتوكول تدأول الكائنات البسيط مه5 وهو بروتوكول بسيط ولكن قوي حيث يستعمل 
تقنية موجودة اصلأ وهي تقنية 1۲۲۲ ويتجأوز مساوئ التقنيات الحالية مثل الکوبرا C08۸۸‏ والدوت كوم 000. اللتان 
تتطلبان شروطا خاصة. 


- مقالات متفرقة من موقع وادى التقنية : أهمية الشبكة الدولية للإنترنت ٠‏ تاريخ Www .İtwadi.cټm +1٠٠۹/1/1١‏ 
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تقنية الدوت نت: ۲٤غ×.‏ 


تقنية الدوت نت 1ع. هي عبارة عن حل متكامل ومتطور من شركة مايكروسوفت لبناء الأنظمة وتشغيلها للجيل القادم من 
التطبيقات والأجهزة والتي تسمج بعملية ربط الأجهزة والناس والمعلومات والشبكات في كل مكان بطريقة سهلة وامنة ومنظمة 
هذة التقنية هي في في الواقع تطویر وتجميع للتقنيات السابقة من أنظمة التشغيل sسwەل0ہW۷1‏ وادوات التطویر ۷8B‏ ومزودات 
الشبكات , ||S ASP‏ تم جمعها في بوتفة واحدة باسم تقنية الدوت نت الموجهه بالأساس لأنتاج التطبيقات للشبكة الدولية وانتاج 
خدمات عبر الشبكة ومءا«م؟ ط۷ في هيئة 01× بواسطة معيار النقل. جمم5 كما تعتبر احدث بيئة تطوير انتجتها 
مايكروسوفت كما ان حزمة البرمجة الجديدة 61..هالںا؟S‏ امںو¡۷ هي الأداة الرئيسية لتطوير الأنظمة لهذة البيئة الجديدة. 
الواقع ان التوجه الجديد الذي تنتهجة مايكروسوفت هو التوجة نحوالشبكة الدولية (الإنترنت) . وبما ان البيئة المسيطرة علة 
هذاالقطاع هي بيئة جافا ۸۷۸ل فكان يلزم علي الشركة ان تنتج منتج منافس لتقنية الجافا . والدوت نت هي تقنية مشابهه 
لتقنية الجافا. 

فمثلا لغة سي شارب # تعادل لغة جافا بينما هيكلية الدوت نت )امس هم"” ه٣۴‏ تعادل مشغل برامج الجافا الأفتراضي اهںاإ!۷ 

Machine .‏ وھذا يعني باختصار ان مایکروسوفت لم تقدم تقنية جديدة انما عملت علي الأستفادة من افضل التقنيات الموجودة 
واضافت إليها (كالعادة) 


ما سب أختيار منتج الفيحوال بيسك دوت نت ۲۰۰۵ 


رأيي هو ان تستخدم الأصدارة ۲٠٠٠١‏ وذلك لعدة أسباب. 


هي بداية أصدارة أحدث من الأصدارة فجوال نت ۲٠٠۳‏ وفيها أمور لا توجد با لأصدارة ۲٠٠۳‏ كما أنني لا أعلم كثيراً عن 
الأصدارة ٠١١۸‏ والمعدة للعمل علي Vista Windows‏ 


ولكن لأ انصح بها ولسبب واحد وبرأيي هو كاف. 


الأصدارة ۲۰۰۸ تستخدم 5 .3 Framework‏ والذي ليس له وجود علي ۹۰ من الأجهزة علي الأقل حتي الأنء والأصدارة 
۲٠٠٠‏ تستخدم ال 2.0 kإمسعء_هإ۴‏ والذي يوجد علي %۹٠0‏ من الأجهزة تقريباً الموجودة الأن › أي أنك لست حتي في 
حاجة الي ان ترفق ال Framework‏ & مشرو عك لدي تسلمیه الي المستخدم. 


حقيقة ان الأصدارة ۲١٠۸‏ تحتاج إلي المزيد من الوقت › ذلك الوقت الذي يصبح فيه s-×P‏ س 1d0‏ مثل اأ 98 Windows‏ 
أو الملينيوم Windows Mil‏ الان„ 


مع ان هناك ملاحظة صغيرة وهي أنني صنعت برنامجاً يعتمد علي ال 1.1 kامسwعمصهإ۴‏ وعمل علي أحسن مايرام علي 
الأصدارة 2.0 Framework‏ واعتقد ان استخدام برنامج علي اصدارة الفجوال ۲٠٠١۸‏ سوف تعمل طبيعيا علي اصدارة ال 
۴ramework 200‏ بحالة واحدة وهي عدم استخدام مكتبات جديدة لا توجد الأ بالأصدارة 3.5 oo‏ وحجم 
الأصدارة 3.5 ٥W 0k‏ طصھا۴. یصل إلى ۱۹۸ ميجا بايت من الملفات والمكتبات. 
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.Net Framework Jed! مقدمة طا‎ 


.Net Framework Jnl! أطار‎ 


هو عبارة عن اطار يغطي كل طبقات تطوير البرامج اعلي من مستوي نظام التشغيل ويعمل كبيئة تشغيلية لتنفيذ وتشغيل وادارة 
التطبيقات المصصمة للعمل تحت بيئتة وتوفير مكتبات موحدة للتطوير مما يسهل انتاج التطبيقات مهما تعددت اللغات 
.Net Framewor)‏ حقيقتا يقوم تغطية أو حجب نظام التشغيل اي يقوم بعزل ألبرامج المصممة للعمل تحت بيئتة عن نظام 
التشغيل وبشكل خاص في الامور التي تتعلق بادارة الملفات وتخصيص الذاكرة وقد صمم لتبسيط تطوير التطبيقات في البيئة 
الموزعة جدا (الإنترنت) ويجهز لجعل عملة في جميع أنظمة التشغيل والمكونات الأساسية لأطار عمل نت يوضح بالصورة 
التالية 


ASP.NET Windows Forms 
ASP.NET Application Services Windows Application Services 


NET Framework Base Classes 


Lomrmon LanNnELageê Runtime 


Mermory Managermëert WOON Type System Lifecycle Monitoring 


' . Net Framework Jnaلا محتويات اطار‎ 


Yisuıal Basic .NET, Yisuıal C# .NET, ... 


لغة التنغيذ الصعشتركة ۸ا٥‏ 


.NET Framework Jaz رlط¦¡| محتو يات‎ 


.Net Framework Jazلا آهداف الطار‎ 


توفير بيئة برمجة موجهه للكائنات 00۴ ثلبتة سواء كان التطبيق يخزن وينفذ محليامه] )وه أو ينفذ محليا لكن موزع علي 
الإنترنت لم ںطاإ)وا أو تنفيذ عن بعد هه ٠"‏ أو لتزويد بيئة ذكية لأدارة الذاكرة والمصادر وحل مشكلة وہ هزءإم۷ 
ولتزويد بيئة تنظيف الأكود البرمجي وهي التي تزيل مشاكل اداء كتابة أو ترجمة البيئات ولجعل تجربة المطور ثابتة عبر 
الأنواع المختلفة جدا من الطلبات مثل طلبات اساسها النوافذ والطلبات علي الإنترنت.كما تعمل لبناء اتصال علي معايير قياسية 
لضمان عمل ذلك المكونة مستند علي اطار العمل بحيث يستطيع التكامل مع المكونات الأخري وهو يتكون من عنصرين هما : 


أ - م / تركي العسيرى : برمجة أطار عمل 6. بإستخدام PDF File › Visual Basic.Ne†‏ » الطبعة الاولي ۲۰۰۳ » ص٥١٠١‏ 
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المكتبات وبيئة التشغيل ويحتوي هيكل ۸6. علي ما يزيد عن 3400 طبقة يمكن استخدامها في متطلباتك تمثل بعض هذة 
الطبقات انواع البيانات الأساسية واغلبية الطبقات مخصصة مهام متخصصة اكثر مثب العمل بنظام الملفات وتوليد وثائى ۸1× 


Common Language Runtime - CLR 


هو أول مكون لبنية اطار )مس م" ه٣۴ .۸٥1‏ ويطلق علية بيئة العمل المشترك وبة يتم تنفيذ كل التطبيقات ويتيح لك مزايا 
عديدة منها التعامل مع الأخطاء والامان وازالة العيوب والتناسق في ملامح البرنامج وهذة المزايا متوفرة لأي لغة مصممة 
لوظائف C1۸‏ وھذا يعني ان مكون C1۸‏ يستطيع استضافة عدد كبير من اللغات ويعرض مجموعات عامة من الأدوات تشترك 
فيها جميع هذة اللغات ولقد دعمت مایکروسوفت لغات ۷8,٥++,٥#‏ بمكونات C1۸‏ وقد سجلت الشركات اسمائها لتقديم 
تطبيقات للغات الأخري مثل ١هطار٥,‏ امم بل وحتي . امطهC‏ يصير هذا الأكود البرمجي الكود البرمجيأ مدارأ 1۴ع فعندما 
يحول المترجم الأكود البرمجي إلي مكونات CR‏ والمقصود بالأكود البرمجي المدار ف الأكود البرمجي الذي يستفيد من 
الخدمات التي د تقدمها مكونات وحتي يعمل وقت التنفيذ مع الأكود البرمجي لأبد ان يحتوي هذا الأكود البرمجي علي مايسمي 
بالميتاداتا هة لهه" وهي عبارة عن بيانات يتم تخليقها اثناء تنفيذ المترجمات لعملية التحويل إلي مكونات C1۸‏ وتخزين 
الميتاداتا مع الأكود البرمجي المحول وتحتوي علي بيانات بشان انواع واضاء ومراجع الأكود البرمجي وتستخدم مکونات 
CR‏ المیتاداتا لتحديد الفئات Classes‏ وتحميلها وانشاء الكود البرمجي اصیل وزیاده مستويات الامان ويوجد فوق مكتبة 
الصنف القاعدي الأساسي ثلات نماذج برمجية:- 


الأول هو ۸5۶.١6۲‏ الذي يستخدم لأنشاء تطبيقات معتمدة علي ويب ويمكن اذكر مابين المزايا العديدة لتفنية ۲آغASP.NE‏ 
ميزة صفحات المزود الفعالة المترجمة وعناصر التحكم بالمزود الجديدة وخدمات ونماذج ويب التي تفصل منطق لغة النصوص 
البرمجية عن لغة وصف الأظهار. 


الثانى هو اطارات ويندوز حيث ياخذ هذا النموذج البرمجي باسلوب لغة فيجوال بيسك ٠‏ في البرمجة المعتمدة علي الأطارات 
ليعممها علي كل مطوري تطبيقات وندوز ويتم هذا بواسطة مجموعة من الأصناف في اطار عمل ٥۲‏ وتعد اطارات ويندوز 
مجموعة كاملة من الأآنماط القابلة لأعادة الاستخدام وهي تبسط تطوير واجهات الاستخدام الرسومية في ويندوز وتسمح 
اطارات ويندوز بذلك ببناء التطبيقات سريعا التي تمتاز باستخدام عناصر اكتيف اكس ×هرء۸ والقوائم المنبثقة وامكانية 
الوصول إلي مزايا الامن في ۲ع 


الثالث المكونات القياسية لواجهة الاستخدام الرسومية مذل الأزرار ودوائر الأختيار وسييتفيد التطبيق لدي استخدم اطارات 
ویندوز , ws ۴2m‏ 0ل Nin‏ من كل مزايا ۸4٥.۸6۲‏ للوصول إلي البيانات. 

وسیستفید التطبيق ايضا من احداث اصدارات واجهة الإاستخدام الرسومية G+‏ وكذلك من خدمات الطباعة بحيث يغدو 
التطبيق قادرا علي اصدار التقارير الشاملة. 


أليه عمل البرمجة للوصول إلي برنامج الهدف: 


البرنامج المصدرىي ("۳هإو١٠إ۴‏ ١٠ء‏ uںه5):‏ هو البرنامج الذي يكتبه المبرمج ومفهوم من قبل الانسان. 
البرنامج الهدفى (nهإوها۴‏ 1ءءمزط0) : هو البرنامج بلغة الآلة. 
لغة الأَلْة (مومuومها‏ ٠"iطعه۷)‏ : هي لغة البرمجة التي تكتب تعليماتها بالشفرة الثنائية. 
المترجم (٠اامهه٥)‏ : هو البرنامج الذي يقوم بعملية تحويل البرنامج المصدري إلي برنامج الهدفي . 
قوم الم بالو ظائف الأتبة٠-‏ 

.١‏ تحويل البرنامج المصدري الخالي من الأخطاء إلي برنامج هدفي. 

. أكتشاف الاخطاء مثل الأخطاء الأملائية › قواعد › تنفيذية. 

۳. ربط الجمل الثنائية وبناء ما يسمى بالبرنامج التنفيذي. 
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الترحمة على الفور ال ' 


من أجمل الأشياء التي ستكتشفها والتي تعتبر فتح كبير- في رأيي الشخصي - في عالم برمجة وهي تفنية ٣ع×.‏ › هو أسلوب 
الترجمة على الفور وہاامصه٥ |١ ٣|٣٥‏ اال - (1١ل)‏ . وهي تقنية تقوم بترجمة البرنامج عند تنفيذه حيث ينتج أفضل 
شيفرة تتناسب مع الجهاز الذي سيعمل عليه البرنامج مما ينتج عنه نتائج إيجابية جيدة جد ›١‏ ( هذا عند الحديث عن تحسين 
الكفاءة وحتى تعلم كيف يحدث ذلك تابع ٥٣‏ ناھص نام ) كما بشکكل التالی. 


كنب باللغة التي تريدها 


رجه ب ٢اا‏ توا 
ترچha omnpiling‏ بنحول ٻرنامج بلغ اا او ا121 


YLtF.NET 


Execution hid 


ننم عليه تنفيذ البرنامج باستخدام 
الئرجية على الفور ٣ال‏ 


Class Library 


Class Library‏ تعتبر المكون الثاني لأطار )مس مص" ه۴۲ .۸٥‏ وهي المكتبات المساعدة والتي تساعد المبرمجين لأنشاء 
التطبيقات وتحتوي بيئة الدوت نت علي الألف منها وهي موزعة في مجموعات a4‏ بهیکل .٤۲‏ وعلي سبیل المثال کل 
الفئات التي تعمل مع نظام الملفات تجمع في تفرع الأسماء m٠ءءرك.10‏ ويمكن ان تشير إلي أي فئة بشكل معين في هيكل ام١‏ 
وذلك بكتابة اسم الفئة ثم اسم التفرع علي سبيل المثال للأشارة الي تفرع الملفات في الفنةَ ص 6اءر .0 يمكنك ان تستخدم 
التفرع هاأ۳.۴٠اءرك.0|‏ هنالك فئة واحدة مهمة جدا خصوصا لبرمجة صفحات 

Sرءاء.W۷ يمكن ان توجد تحت الْفْنةُ م‎ ۸5۲.۸٥ وکل الطبقات التي تتطق بهیکل‎ SP. 


ملغفات المکتات Assemblies‏ 
الطبقات في هيكل ال ٤م..‏ تجمع في ملفات تسمي ءءiاطص‏ ءءء ومن المهم عدم الخلط بين الملفات ءءiاط"‏ ٥ءء‏ وبين 


الفئات فالملف وءiاطص‏ ٥ءء‏ هو الملف أو الملفات الفعلية التي تحتوي علي الأكود البرمجي للطبقات الفئات علي سبيل المثال 
كل الطبقات في الفئة 10.٠٠ء1ءرك‏ تقع في الملف |ال.طامءء وهو الملف الفعلي الموجود علي قرص التخزين 


| SE ET bl FJai FTE 4 5 E rm BDF File FFP OTE 
HE OE 1 FB mHEZOTE 1 EFE -ALE1 Lore EELEr Ty DES 

| Sytem Sgt eam, AL 1 ZLE-=speciME gystem typES 
TE ET , TEE TB Tyagi, HATE. A1 J کد‎ CD. HET 

| SyaCeTa, DIFEGFTOE TFIETTICEm SACLE, MECETSTOE TITTIES AI 1 BC TIRE DOIFECTOPFY 
SSA TET. FE AW LEO Tater, DE AFI: A11 irr oa 5 QFap TiS fir tiorktalit 


Sa CET. EHTEFPFISESETTITGEeEA Fg Ce. EOTETpEF ISE ETTICcEN. MLL Services formerly knower as COmM+* 1-0 


a E CET BEATE EEE TIE Fat ET Ha rE reETE THC , CL 1 gal COMpGLUTEF FARANMNAQEFNETIT 
| SFE TET „ BE THEA LEU FTA ETN. HE HE OT LEL - A1 ASE FESSIAQIND SEPFWICES 
| TTa TET, SETUTITY FTI ETN. TETUAT ITT. AL FProqFaranmiatiz sec UFity 
Sa CET „. HEK Tate. YER, QALI پر‎ ۴ ET 
| STA TET. HEE. SETCTLTEA TTT. VED. ETT LTES ALI AAI ILE ISR eM HETTITCE AUpGCpPOTE EOE 


ASF .HET 


j STE TtETm . VIG ta - FOLCTHS Fate, FI Agog . FOF A1 1 Windows Forrns framework 
I STA CET. AOU ITEC. AOL ALI SAFE OEE TOT pGPEOGE HII 1 ELE taikb 1# 


Earp Lanaüuage [ML 


MISCO SOFCFE-.FWFI1SusS LESSIG HEI1ZTEuSDCE-- VIS LlLBHosalc . CLL Wass 1l Hassle melts. GOM STSTMTCES; BSBA 
ewE EE 1DGESS 
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الحزء النانى التعرت على برنا Visual Basic.Net 2005 Q4‏ 


۰¢ 


طريقة تثبیت الفیجوال بيسك دوت نت ۲۰۰۵ 


Microsoft Visual Basic 2005 Express Edition چaliرڊ‎ Jınحتل‎ 


@ Visua | Basic 200 


CTO ار‎ 


ss Edition 7 


الرابط : 


http ://download.microsoft.com/download/D/9/C/D9C35F20-A749-4E25-A306-DE20B93AB8C0/VB.iso 


بیئة 2005 ٥ہ.طv‏ أو كما یعرف 5| وهي أختصار|ا آ integrated development environment‏ › والفیجوال بیسك دوت 


نت امم. ۷اط امuوا‏ هي أحدي اللغات المتاحة داخل أمم.هالںاء امuور‏ بالأضافة إِلي , أne. visual c# .net , visual j#‏ 
visual c++.net‏ 


وبينة أم.٥اووط‏ اهuوا»‏ هي بيئة متكاملة لأنشاء وتصحيح التطبيقات المتنوعة متثل مدااجء‌ااممجة sسwملہاس‏ وغيرها من 
التطبيقات المختلفة. 


iê Yısual Basic 210b Express Edition Setup كا‎ <) 


EOE 2 
Visual BaSIC 2005 
Express Edition 


Salem4it.com 


WEISaOE to the WIsSUal BDasIc ZULUNS Express Edition Installation wizard, Wisual Basic 
Z2UUS5 Express I5 a llghtmwelght tool that makes It very Easy to learn how to build 
rich Wwindoams applications, and to Jalna community of hobbrist programmers, This 
wizard will Şulde you through the process to Install this program and any 
prerequisites needed on this cûornputer, 


Help Improve Setup 
Tol Gan sUbrnit anonyrrnous Information about your Yisual Studio setup 


Experlences to Microsoft, To participate, check the box belovy, 


es, send information about my setup experiences to Microsoft Zorporatkion,‏ ا 
TEL : : : :‏ | 
li} For more Information, click Data Collection Policy‏ 


a FFE VIOUS ٠ | ١ LER 
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iê Yısual Basic 200b Express Edition Setup ك‎ 5) 


Most 


` End-User License Agreement : Vicual Basic 2005 
ا‎ | Express Edition 
Salem4tit.com 
ûccept the terms of the License Agreement to continUE, 


End User License Agreement 

Be sure to carefully read and understand all of the rights and restrictions 
described In the EULA, Tou will be asked to review and eIlther accept ûr not 

accept the terris of the EULA, This product will not set up on your computer 

unless and until you accept the terms of the EULA, For your future FEfEFENGE, 

yol mary print the text of the EULA from the eula txt file of this product, Toul 

may also receive a copy of this EULA by contacting the Microsoft subsldlafy 
SeEFYINQA ¥YOUr country, ûr by writing to : Microsoft Sales Information 

wenteffDne Micrûsoft WayfRedfnond, WA 48052-63939, 

| 


I haYve read, understood, and agreed on the terms of the End-lUlser LIcENSE 
ûgreermnent and so slqnify b¥ clicking "I1 accept the terrns of the License Agreernent" 
and proceeding to Use the product, 


t the terms of the License Agreement 


POSSE 


x Prevlols | | 


i yisual Basic 2005 Express Edition Setup 


ا 


SEL 


` Installation Options VisU al Basi C2005 
Salemadit.com Express Edition 


Select the optional productis} You would like to Install: 


2 Microsoft MSDN 2005 Express Edition alg ةي™کaلl‎ 


The MSOM Express Library contalns additional product documentation for all 
- isulal Studio Express Editlûns, Tou can choose to Install MSOM ExprFess 
Library at a later time, See the Readme for more Information, 


Microsoft SQL Server 2005 Express Edition الأسكول سیر گر 86ب‎ 


۳ TEQL Server Express is ã basic version of Microsoft SQL Server that allows 
- rol to Easlly read, write, and deploy application data, 


the Readrne file,‏ ی 
ROWSSEF‏ 
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iaıyisual Basic 2005 Express Edition Setup 


es | ViSUal BASIC 2005 
Salenmnait con Express Edition 


Select the location where you would like to Install Yisual Basic 20U05 Express 
Edition. 


Install ir Folder: 


Program Files\Microsoft Yisual Studia 81 


The tollowing products will be installed: 
Microsoft YET Frarnework 2,0 
Wisual Basic Z005 Express Edition سبيت القيجوال مع‎ 
Microsoft MSDN 2ZOD05 Express Edition الأدوات المهمة‎ 
Microsoft SOL Server 2U05 Express Edition x36 اسيتم شر خها لاحها‎ 


Disk space requirements: C: 1.5 GB 


و 
YOWESSEF‏ 


MIs 
ViSUal BASIC 2005 


Express Edition 


AT E arE ا ا ا‎ co mputer! 


` Microsoft .NET Framework 2.0 
Yisual Basic Z005 Express Edition 

. Plicrosoft MSDN Z005 Express Edition 
Microsoft SOL Server 2005 Express Edition x#Bû6 


Currently Installing (1 of 4}: Microsoft NET Framework ZA ,Û 


کت 
YOWESSEF‏ 


waricel 
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HB Start Page - Microsoft Yisual Basic 2005 Express Edition 


File Edl Wie Tools Window  Lommunity Help 


3 


O‏ | ا ي جا ةا حا ل ا لا ا 


Ex‏ ا 3% Starl Page|‏ ر 


METIS 


Visual Basic 2005 Salem4it.com 


Express Edition 


oq] 


Hecent Projects Yısual Basic Developer Hews 


The current news channel might not be valid or: 
connection might bE unavailable. To change th 
on the Tools menu click Uptions, [hen expand E 2 
click Startup. 


انتهينا من عمل البرنامج واصيح جاهزا للأستخدام 


pen: Project... 
Lreale: Project... 


Getting Started 


Hom Dol... ? 

halts Rew IM Wilsall Basile ZUOB? 
Lreate Tour First Application 
Ise a Starker Kil 

Learn Yisual Bazlz 

Lonnect wth thE Corîriuity 
Download Additonal Carter 


| 11 0 


New Frojeci 


Templates: Salem4it.com 


Yısual Studio Installed templates 


WS lass Library Lonsaolê My Movil Scrêef Saver 
Applicaton Application Lollectl... Starter Ei 


My Templates 


وشدهة شي المكوتات الرنيسية لليرتامج نلاحظ انه لأيوجد أي لقة سوى لقه 


Search Unllne 
Templates... 


project for creating ãf application with a WIndows User Interface‏ ت 


CTT EEE 
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التكرف على الواجهة الفيجوال يسك ٠٠١۵‏ 


ES 


Microsoft 


' e Visual Studio 2065 


Integrated development environment - |DEفر#ي‎ la أو‎ 
VISUAL BASIC.NET 


هي احد اللغات المتاحة داخJ‏ ڊبرliمSTUDIO.NE7T VISUAL‏ 
بالأضافة إلي 


VISUAL C#.NET 
VISUAL J#.NET 
VISUAL C++.NET 


وبینه BA|.N٤۲‏ ا۸ل هي بيئة متكاملة لأنشاء واختبار وتصحيح التطبيقات المتنوعة مثل 


WINDOWS APPLICATION 

WEB APPLICATION 

CLASSES AND CONTROL LIBRARY 
CONSOLE APPLICATION 


بالأضافة إلى غيرها من التطبيقات 

مثل تطبيقات قواعد البيانات وتطبيقات الهواتف الذكيه..الخ 

وعند فتح برنامج S1910.‏ ال۷5 للمرة الأولي سوف تظزظھر Choose Default Environmant Settingsili Û‏ 
وتظهر هذة النافذة اذا كنت محمل S۲0 910.٤‏ ا۸ل فقط وهي لأختيار اللغة التي تريد ان تكون افتراضية عند دخولك 
إلي SUL STUDIO.NET‏ فقم باختیار بیئۂ 8B A۸81٥‏ ۷150۸1 کما بالصورة 


89 Choose Default Environment Settings 


HA roro 


Visual Studio 2005 


Before you begin uzing Wlsual Studio for the first Hme, pou need fo specify fhe tppe of development 
activity pou EnAaãqE ir he most, such a3 Wisual Basic or Wisual CR. Wisual Studio uses this 
information ta apply a predefined collection of szetlngs to Ihe development environment that [s3 
JEezlqnEed for pour deweloprient activity. 


Tou can choose Io use a different collection of selttingz3 


Import and E#port Settings and then choose Reset all 3 4 0 U S S ef 


Choose your defaull enyvironmenlt sellinqgz: 


aeneral Development SetiaAs | Deseriplton: 

Wisual Basic Development S5 elNAz | Uptimizez the Environment sû you can FcuUSs on 

Wisual CH Development Set building world-class applications. This collection of 
seings contalns cu2tormlzallons lo he wirda 
layout, command menus and kepboard shortcuts to 
make carmmon Ylsual Bazll coarnmarfıdz rîore 
actesszlble. 


| Start Wisual Stadia | Ezit Wisual Stadio 


ثم قم بالضغط علي jزر Star Visual Sîudio‏ 
بعدها انتظر قليلا بينما يقوم الفيجوال بالقيام 
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بعمل اعداد بداء العمل ثم سیظهر ك START PAGE Î‏ 


e imad A pp rain? - Hierotoft 


ا 


FA COLD 


Visual Studio 2005 


agen 


RECENT FFIEC E EN Nil ETE E 


et Thea Ga oR rawr 2ha frre 3 
ijl Fi E rejhF He ıqaw akele. In rf —- 
ل‎ Fe E pfinc, Fhe pire Fnapeie 1 
ُ 
3 
. 
5 
1 
3 
3 
poni ti Woz Sk ا‎ 
Piye, WEE LRE 


eli iy Sarl 
aa iê Û... î 


Rag * gê 1 Yg EF a 
alae Tur Tal pian 
> a ا‎ | 

aI zl Ez1 

a FF Fr RFE Soi 
nla AS USE i DET 


وبها تظهر اخر تطبيقات تم انشائها أو تعديلها ولكن هي لأ تهمنا الأن قم بالضغط علي قائمة 
New Project lia رjتخا g FILE‏ 

وستظهر لك نافدة ٥W Project‏ لتختار منھا التطبيق الل ي ترید ١‏ انشائة 

لأحظ هذة الصورة 


Mew PFrojecl 


E]: Yîsual Basic | Yisual Studio installed ternplates ا‎ 


ي لو ي ل ا 


atatter kis lass Library  Cenecle Wirdoms Wek Cotrol 
Fi: Oher Laf ê2 applica Carol lbrar# Liîrasy 


Gtr Freject Types 


Windom Emply P"gject e 
Repl. 


Mr Templates 


aaa | YOUSSEF 


EZ. 


علي إليسار يوجد نوع المشروع الذي تريد انشاء احد تطبقاتة وعلي إليمين تظهر تطبيقات المشروع 
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أنوا ع المشاريع: 
يمكنك أن تري كل أنواع المشاريع المتاحة ‏ بخلأف تطبيقات ويندوز - في مربع حوار "مشروع جديد" وهي كالتالي: 
سكت !لخب : Class Library‏ 


وهي مكون أساسي لبناء الأكود البرمجي» ليس لها واجهة مرئيةء ولكنها تودي وظائف معينة لبرنامجك. 
وباختصار» فان الخليّة هي مجموعة من الدوال والأجراءات التي يمكن إعادة استخدامها في أي مشروع» بحيث يوفر المبرمج 
علي نفسيه مشق إعادة كتابتها مرة أخري. 


Windows control library :ianis : مكنة دات‎ 


إن أدة ويندوز - أو الأداة علي سبيل الأختصار - هي عنصر أساسي في واجهة البرنامج» مثل مربع النص أو الزر. 

فإذا ما وجدت أن الأدوات التي يمنحها لك ۷8.۸٤۲‏ - وهي التي تظهر في مربع الأدوات تلقاتيا لأ تمنحك الوظيفة التي 
تريذهاء ففي هذه الحالة يمكثك أن تب تبنى الأدوات الخاصة بك. . إن هذا يبسنط عملك فيما بعد حيث لن ثضيع المزيد من الوقت 
والجهد في تصميم أجزاء من واجهات تتكرر كثيرا. 

بل يصل بك الأمر ‏ لو كنت خبيرا في تصميم الأدوات الخاصةء إلي أنك تستطيع بيعها للشركات والمبرمجين الأخرين.. إن 
صفحات مجلأت الكمبيوتر تزخرٌ بالأعلانات للعديد من الأدوات الخاصَة المتطورة» التي تكملٌ عمل الأدوات الأصلية. 


Windows service خدمة ويىدوز:‎ 


وهو الأسم األجديد ڏآ Services NT‏ القديمة. . وهذا النوع من المشاريع»› ما هو إل برامج طويلة التشغيل تعمل في خلفية نظام 
التشعغيل» دون أن تعرض واجهة مرئية. . ويمكن لهذه الخدمات أن تعمل تلقائيًا بمجرد تشغيل الجهازء كما يمكن إيقافها لفترة ثم 
إعادة تشغيلها. 

إن البرنامج الذي يتفاعل الملفات علي الجهاز ويغيرهاء هو مرشح رئيسي لأن يكون خدمة ويندوز» حيث يمكن لهذه الخدمة أن 
تؤدي بعض العمليات» فور أن ينقل المستخدم بعض الملفات إلي مجلد معين» كأن تنسخ الملفات أو تقرأً محتوياتهاء أو تحذث 
محتويات قاعدة بيانات ...وهكذا. 


Console application :رliخÎ1 تطبيق‎ 


وهو تطبيق ذو واجهة استخدام محدودة جداء هي أقربُ ما تكون لشاشة الدوس 005 السوداءء حيث يتم فيها إخراج النواتج 
وإدخال البيانات» علي سبيل اختبارها. 


ASP.NET Web Application :تنرتi'!1 تطبيق‎ 


إن تطيبق الإنترنت هو واحد من أكثر السمات الجديدة في ۷/5.١‏ إثارةء وهو عبارة عن برنامج يمكن تشغيله علي شبكات 
الإنترنت» يمكن طلب خدمات معينة منه عن طريق متصفحات الشبكة.. وأوضح مثال لذلك› هو محل كتب يعرض ويبيع علي 


الإنترنت. 
ويجب علي التطبيق الذي يعمل علي الإنترنت أن يستقبل طلبات العملاءء ويرد عليها في صورة صفحة من صفحات الإنترنت 
HTML.‏ 


ومثل هذه التطبيقات ليست بجديدةء ولكن الجديد هو أن ۸5۴.۸۲ صار يعزل المبرمج عن كثير من تفاصيل بنائهاء مانحا 
الكثير من السهولة والسرعةء ومحولأ العملية إلي ما يشبه كثيرا بناء تطبيقات ويندوز التقليدية. 
وسنناقش بالتفصيل خدمات وتطبيقات الإنترنت في آخر جزء من هذا الكتاب إن شاء الله. 


ASP.NET Web Service:i خدمة الاإنترز‎ 


وهي ل تکافئ بحال خدمات ويندوز» بل هي عبار عن برنامج يعمل علي خوادم الإنترنت ۲٥۷م |٥۲٣٥‏ لأستقبال 
الطلبات» تمامًا مثل تطبيق الإنترنت» ولكن دون أن يرد بصفحة من صفحات الإنترنت» بل يرسل ناتج العملية الحسابيةء أو 
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المعلومات المطلوبة من قاعدة بيانات ماء وعادة ما تطلب هذه الخدمات من قبل خادم إنترنت آخر» حيث سيتولي هو التعامل مع 
البيانات. 
ولتوضيح الفارق نضرب هذا المثال. 


إن تطبيق الإنترنت الذي يتلقي منك استعلاما عن كل كتب (توفيق الحكيم) سيعرض لك صفحة عليها أسماء هذه الكتب.. أما 
خدمة الإنترنت التي تتلقي منك نفس هذا الأستعلام» فسترسل إليك ملف 01× يحتوي علي أسماء الكتب المطلوبة» حيث يمكن 
لتطبيقك في هذه الحالة أن يتعامل مع البيانات ويعرضها في صفحة جديدة بالشكل الذي تريده» ويرسلها للمستخدم الذي تريده» 
أو ربما تعرضها علي نموذج ويندوز عادي. 


Web Control Ii} rٽary:ٽنرتiإ'1 مكتبة أدوات تحكم‎ 


كما أنك تستطيع أن تبني أدوات الويندوز الخاصة بك لتستخدمها علي نماذج ويندوز» تستطيع أيضًا أن تبني أدوات الإنترنت 
الخاصة لتستخدمها علي نماذج وصفحات الإنترنت. 


أما القوالب الثلأثة المتبقية في مربع حوار "مشروع جديد"» فهي: 
1- شرع lرğ. Empty Project‏ 
۲- مشرaع‏ إiترنت‏ lرğ. Empty Web Project‏ 
۳- مشروع جدید قي مجiد‏ مgجg. New Project In Existing Folder‏ 


وهي ليست أنواع مشاريع بالمعني الفعلي» بل مجرد طريقة لتنظم مشاريعك الجديدة بنفسك» فحين تختار واحدا منهاء ينشئ 
7 مجلدا جديدا يحمل اسم المشروع» وينشئ فيه بعض الملفات القليلة التي يحتاجها البرنامج من هذا النوع.. وعلي 
عكس الأنواع الأولي - حيث تقوم ۷5.۲ بإنشاء عناصر افتراضيَة والملفات اللازم ة لهاء كإنشاء نموذج مبدئي في تطبيق 
ويندوز» وإنشاء أداة المستخدم في تطبيقات أدوات ويندوز - تحمَلك هذه الأنواع الثلأثة مسئولية إنشاء وإضافة ما يلزمك من 
العناصر والملفات. 


حددناه وفي الأسفل النافذة اسم المشروع و يمكن ان نغيرة إلي الأسم اللذي نريدة نختار الأن احد تطبقات 
۷|SUAL BASIC.NET‏ وسنختار من هذة lئdliفذة WINDOWS APPLICATION‏ 
ثم نضغط موافق سوف تظهر لنا قوائم وادوات ونوافذ لغ 7غN.°BAS|C‏ ال5 هذا 


E Windows pplication] ¬ Microsoft Yisunal SI0dIio 
Ell Eft Wem Project Buld Debug Lata Farmall Tools Windom Lommuirlty 


= ج 1 j 1iJ‏ 2 ر ت اا EE.‏ دايا ا ا ر لقا = لا 


olution E #plarer‏ 3 ا ا | “Forml.¥b [Design]™"] Start Page‏ و 


BS MEE A 
أ‎ WYindowsA pplication 
| My Project 
Ea] Forml.wb 


E Solution E #plarer a Lata SDUrCES 
Fropertiazs - HH 
Form] System. windows. Forms. Form *™ 


StatPaositian loys efa 
Tag 
Tent Form Î 4 
TopMost False ا‎ 
Text 
The test associated with the control. 


4 0 234 
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لأظهار قوائم الخصائص أو الأدوات نقوم بوضع المؤشر علي اسماء القوائم الموجودةلأظهار نافذة الأدوات من القائمة س٥۷‏ 
واختر ٠٠٥۱8٥۸‏ أو بالضغط علي×+۸1+ا١]C‏ واذا ظهرت النافذة بشكل منطوي تحت احد جوانب نافذة الفيجوال ستديوما 
علينا الأ الضغط علي الزر الأوسط الموجود في اعلي أي نافذة الذي بهذا الشكل 


وبعد تثبيت قائمة الأدوات سيظهر شكل الواجهه هكذا 


9 YindowsApplicationl - Microsoft Yisual Studio 
File Edl Yiew Propectl Bulld Debug UOala Faormal Iools Windom  Lornrnuinity 
آ - 1 چ کد‎ f ج ا ج ا کی ا ا وا‎ E CE E 
e H x | Forml.¥b [Design] Start Page | 
2 ll Yindows _ x | 


Form Î - RF 1 tp e a eT) ۳ 
ّ | E] My Project 
. CE] Forml.sb 


| E Solution E... . لو‎ Data Sout... 


| Properties H1 E 


Forml System. windows. Forn 


إا چ 
تش SIE rIpS HY „Auto‏ 
StartPoasilor WIndomslU efa‏ 
Tag‏ 
Test Form]‏ 
TopmMost False‏ 
Transnarenr Et‏ _ 
Text‏ 


| The text associated with the 
| control. 


۳ 


| 


1 


E Ê kr Û 


ي 
را 


251 + 229 


وفي الجهه إليسري تظهر قائمة الأدوات وسوف نتعرف علي كل اداة موجودة بها في الدروس القادمة 


ويظهر بالجهه اليمني نافذة orerام×٤‏ ionاuاەS‏ واسفل منها نافذة الخصائضص5ع| ٥م٥۴۲‏ 
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ولکن ما ھو الفرق بین ٢٥‌ااں‌اه5‏ ( المشروع ) وال ( c۲‏ ءزہإم التطبیق) ؟ 
اءەزدا۴ أو التطبيق: 
هو عبارة عن محتوي للمكونات الخاصة بتطبيق ما مثل النماذج ء٠۲۳٠۴‏ وكل الأكواد البرمجية 
Classes yÎ Modules J‏ 
ومع بداية ظهور لغة ٤۸.6.ط۷‏ ظهر ما يسمي( ہ٥iاں‌امك‏ المشروع) وفائدته تنظيمية لل وامزهإ۴ 
ويعتبر ال مioاu‌امS‏ مساحة العمل الخاصة بالدوت نت فمن الممكن ان يحتوي علي اكثر 
من تطبيق 1ء هزه۲٥‏ بداخلة وتستطيع ايضا اضافة مكونات خارجة عن أطار الأكود البرمجي إلي هاںاه5 أي حتي ولو لم 
تتعلق بالكود البرمجي التطبيق كملف وورد أو صورة أو ملف صوتي وبالتالي تستطيع استخدامها داخل تطبيق الدوت نت توجد 


النافذة orerاE×p‏ nەiاuامS‏ في الجهة اليمني كما يمكن اظهارها من قائمة سه۷ أو بالضغط علي 1+ا۸+اإ]٥‏ وتعمل علي 
عرض عناصر ومكونات التطبيق علي هيئة قائمة شجرية في اعلي القائمة يظهر اسم التطبيق الحالي ويليه بقية مكونات 


| lution i plate er 


ip howsA nınli a1‏ أ 
TE‏ 


E- i obi 
HE: 


= HES 


ونستطیع اضافة عناصر الي التطبيق الحالي من خلال النافذة Solution Explorer‏ وذلك بالضغط علي اسم المشروع بزر 
الماوس الأيمن ثم ١ه‏ ومنة نختار New |٥‏ 


ن 
j| Eodsking Ibe... Add Reference...‏ 
Cj New Folder Add Web Refererce...‏ 
IE] Windows Form... | j View Class Diagram‏ 
Î User Control... Debug‏ 
ci] Component... HF Add Project to Source Control...‏ 
د 
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وبعد الضغط علي ۳٥ا ۸٥W‏ سوف تظهر لنا نافذö Add New Item‏ 


Ali Hew terî - Hm Tes Ap pire Bo F1 


Templates: 
Visual Shudio installed templates 


Explorer Formi MIM Farerê boit Box Login Fatmi plazh Steer 
Farm 


س2 إك @ 
Cemponett‏ 


Diket ata TOM lass i 1 CK Repork Cryekal Report 


ق 


leer Control Irherbed Ect Inher edl Le ibo 
onir ol oir 


A blarik Wrudes Fort 


hla: EGF TE bı 


وبها العدید من تطبیقات آ٤N. S10‏ ا۸ل نختار منها ما نريد اضافتة إلي تطبقنا الحالي 
Windows ۴m‏ وھنا مثلا سوف نختار 


قم بالتاشير علية ويمكننا تغيير اسم التطبيق قبل اضافتة من اسفل نافذة ها سم ۸44 أو نتركة كما هو ثم نضغط علي الزر 
هههفنلأحظ اضافة ۴٠۲۳‏ اخري إلي التطبيق تاخذ الأسم ۲ ۴٠۲٣۳‏ وتظهر في lأمة solution Explorer‏ 


كما بالصورة 


E E2 -‏ ف ر 
WindowsApplication1‏ 3 

A) My Project 

-2| Form1.vb 

5] Form2.vb 
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"Menu التعرت على القوام‎ 
Menus With Visual Basic.Net 2005 


إليوم سوف نقوم بالتعرف علي قوائم الفيجوال بيسك دوت نت ١٠٠تتكون‏ قوائم الفيجوال بيسك دوت نت من ازرار عديدة 

لها مهام مختلفة والأزرارموضوعة علي القوائم المخصصة لمهامها وسوف نتعرف علي عمل معظم ازرارهذة القوائم أو بقول 
اخر سوف نتعرف علي اهم ازرار قوائم الفيجوال بيسك دوت نتوذلك للتعامل بسهولة مع واجهة الفيجول بيسك كذلك لمعرفة 
قدرات هذة اللغة القوية قد تلأحظون في صور الشرح التي وضعتها بهذا الدرس اختلاف بين قوائم كم وهذة القوائم اختلاف 
ترتيب الأزرار أو وجود ازرار اكثر بقوائم بلا تخافوا يمكننا تعديل قوائم الفيجوال بيسك دوت نت من حذف واضافة وترتيب 
اران يم نتاس متطلباتا واحتاجتا وذك من الكائى 5أوة٣‏ فم ناختل 6 "فارع ستظهر لك ناقة قم باختار التبوب 

الثاني وستظهر لك كل قوئم الفيجول بالجانب الأيسر وبالجانب الأيمن يوجد ازرار القوائم قم باختيار أي قائمة ثم من ومن 
الجانب الأيمن قم بعملية السحب والأفلات للأزرار التي تريد إلي القوائم اللتي تريد ومتي تنتهي قم بإغلاق النافذة مہ oاوCu‏ 
ولقد قمت بتقسيم هذا الدرس إلي جزئين والأن فالنبدا مع الجزء الأول ومع أولي القوائم بالفيجوال بيسك نت 


[File] 


وتتكون من ازرار الأوامر التي تتعامل مع انشاء وفتح وحفظ وإغلاق كلأ من الملفات والمشاريع 


SS WYindowsApplicationl - Microsoft Yisual Studio 

E ıt Buld Uebug Uala Tools: Windom LL 
ل‎ Mey Project... 1 Ltrl+f 

pen F FF Hew'w'eb Site... @ 

Add | File... )3[ atior 


hew Prafect 


Prapect Fram Emısting Lode... 


Llose 
Llase Prapect 
ave Foml.yb Ltrl+s 
ave Forml.yb Az... 


ave All Ltr hift+h 


Export Termnplate... 


Tource Control 


Fage Setup... 
انشاء مشرو ع ا۷ جذید‎ - [1 

انشاء تطبنق انترنت جذند 
انشا ملف نص او زسوهی الح 


Print... Ltrl+F 


Recent Files 
Recent Projects 


E ıt 


أ - بواسطة المخلب الجارح » دورة تعليم الفيجوال بيسك دوت نت ۲٠٠٠١‏ " بأسهل الطرق "' » منتدى فيجوال بيسك. 
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ج 


إل ۳ظ ا -_ 7 کا د 


pen Project... Ltrl+l @‏ ا 


Ta YYindowsApplicationl - Microsoft Yisual Studio 
E dıt 


Yew Project Buld Uebug Datla Tools: Window  LCormrnunity 


FJ eı 


Add + Ê Open web Sie... @ 


E? Open Fils... 3 


Lloze 


| Llasze Propect 
lÎ Save Foml.sb Ctrl+S 


awe Forml.wb As... 


E  Savedl CtrleShift4S 


Export Teriplatë... 
Source Lontrol 
فتح مشروع ا۷ سابق‎ -1 
قتح تطبیق انترنت ساپق‎ -2 
Recent Files فتح اي نوع من انواع الملفات‎ -3 
Recent Frojects 


E ıt 


File | Edt  Yiew  Propect  Buld Debug Uala Tools Windom  Lorimu 


e ا ا د3 اء‎ j 


pen ۴ 


a ۴ 


Cloze 1 


i] Llose Pro|ect 
WÎ Save Foml.sb Ctrl 0 


Save Forml.yb Ãz... 4 | 
Î SavedAl cms @ 


E«part Ternplate... O 


1- غل الصلف الصحدد ۴ Source Lontrol‏ 
2- علق كامل للمشروع 

3- حفظ التخيرات على القورم 

4- حفظ الفورم كملف اخر جديد 1 
5 حفظ جميه التغبيرات بالمشروع ۴ Recent Files‏ 

E:‏ استخړاج نر او کل اضر 
الفسرويع وضقطها وحفظها 

ا“ تخداد بوقت ار @ E «ıt‏ 
7- اغلاق الفجول دوت ثت 


Recent Frojects ۴ 
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[Edit] 


تحتوي هذه القائمة علي الأزرار القياسية التي تعمل علي الألغاء والتراجع والنسخ والقص واللصق 
والحذف وتتlaمJ text and other objects.ga‏ 


E YindowsApplicationl - Microsoft Yisual Studio 


File | Ed Wie Project Buld Uebug Uala Tools Windom Lommunik 


E 1خ کے‎ 
a EFE anl Ctrl+ 
ا‎ 
۴.1 Lelate Leal î 
Find and Replace ۴ 
Gao Ina... 
Select ۉۇ؛ll‎ Ltrl+ك‎ 
Insert File As Tet... ]2[ يتنشحل شذا الخبار بجد‎ -1 
AdYarcEed ۴ ات نص بباستخداصة تستطيد‎ 
استتجا دد‎ 
Bookmarks ۴ yT 
Outlining Fk اضافة اک ملف کو‎ -۶ 
Intell erse ۴ صقا‎ 
Heamt Method Ltrl+FaUr 
Previous Method Ltrl+Fallp 
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File i | Yi Project  Bulld Debug ÛOata Tools Window Lommunityp Hel 
کڪ ع‎ è‌ ıı ag * 
E ٤ | 
8 4 dd Lut Ltrl+e | ¥ (Declarations) 
a EE Maal Ltrl+ 
E: 
۴ Delete Del 
.  FindandReplace ¢ ard .  FindandReplace ¢ ۴ 8 DM uick. Find O Ctrl+F 
laa lo... 4 Huck Replace O Ltrl+H 
Select ¿ll trl + [ê Find in Files O cin-sniter 
Insert File &z Tet... ^ê Replace In Files Ltrl+Shift+H 4 
Advanced 6 jê Find Symbol 5) Alt+F12 


Bookmarks 
البحت عن نض‎ -1 

٭- ايستبدذ ا لض 

3- البحت عن نص صع حرض النتاتج کقاتحد 


Outlining 


lntelllS EFzE 


4- استبداك نض صع حرض النتناتج كقاتحدة 
5- البحت عن حلت 
6- اضافه تنسفات النضصن 


Mest Method Ltrl+Fgln 
Previous Method Ltrl+Fgallp 
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[View] 


تتكون من الأزرار تلك التي تقوم باخفاء واظهار كل نوافذ واشرطة الفيجوال بيسك دوت نت 


FS YindowsApplicationl - Microsoft Yisual Studio 


ray 


Loamrnurnity 


1- اظهار الجنصر الحصحدذتة بنحصط تحرير الكوت 
#- اهاز الجنصر الصحذد بنحط التصصيصم 

3- اظهار صستجرصضص الحصشروع 

4- اظهازر مستعجرصضص الذخطاء 

5- اظهار خحصائتص الحصشروع وصناصرة 

6- اطچاز صندذ وق الذدذوات 

7- اضاقة وحذف اشرطة الذتتصارات 


Project Buld Ûebug DUata 


Designer @ hifteF 7 


Serer Explorer Ltrl4كéll+5‎ 
Solution E #plorer Ltrl+F 3 
LIbpect Browser F2 | 


Error List Ltr, Ltrl+E 4 
Properties WY lndany O F4 
Tanlbos O CtrlrAllre 
ther WIAs ۴ 
O + 


Shiflailt+E nter 


Toolbars 


Full ScreEr 


Pending LheckInzs 


[Project] 


۴ 1 Lode 31 Fr 


File Edi | Yew 


3 


تتكون من الأزرار التي تقوم باضافة وحذف العناصر من وإلي المشروع 
وهذة القائمة نستطيع القيام ببعض أوامر ازرارها من النافذة 


Explorer Solutions 


والخيار الأخير بالنافذة كما عرفنا هو لعرض نافذة خصائص المشروع 
والان سوف نستعرض اهم خصائص المشروع 


AppIiction پڀوبتll‎ 


ومنة يتم تحدد نوع المشروع وبياناتة 
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e YindowsApplicationl - Microsoft Yisual Studio 


Forrnat 


@ 


Tools WY irdany 


ا > 


# Il _ & 


Ltrl+l 


1- اضاقة تليق :حدذبد للصت رو2 
2- اضاتهة تطبيق حصحجحضر حبقا 


3- اضاقد ةاد صگونات اضافیه 
4- نج ناقذة خصاتص الصشروع 


Ltrl+5 hift+A 


Add Existing Iter... © 


E «clude Frarn Project 


Lata 


Debug 
Add Windows Forrn... 


add Web Reference... ٍ 
Wndonshpplicatlonl Propertes... 4 


Fila Edit 


Yiewy | Project Build 


Add lser Lontral... 
Add Laormponert... 
Add Module... 

Ad Llasz... 


کک 1 |4| 


Add Hew lte... 


Ê Show All Files 
Aid Reference... 


Lommuruty Help 
ıl ga u LE a | ol N Hd 2B O 
e 
Fool namespace و‎ 
WmdowsA pplication 
lcort ۰ 
Delauk Icon) © ` 


Assembly Infomaliar... 4 


1- تحذيد لوغ الصشروع 
2 تكذيذ قورع بذاية العمشروع 
3- تاديد ايقوتة للمشزوع 

4 تيد بيانات الشروع صلل 
انسعة والشركة ...الج 
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WindowsApplicationl = Microsoft YIisual Studio 
al 


ا 


Fle Ed View  Pioeel Bild Dekaiig Dal Tonls 
WindowsApplication1"]’ Fouml.yb [Design] 7 Stal Page | 
Applizaion 
ق‎ Eb nam#: 
Compile WW mdowsA pplication 
Debug Apphcatlon type: 
| Wwirrdows Application O 
References 
Starliap Fafî 
Resources Form 2 
Setlirigs Enable appheatlon framework 
Signing Windows application frarmewark propesties 
Secuily” Enable XP visual styles 
[|_|] Make single instance application 
Publish 
l#j Save My. Settings on Shutdown 
Authenkication trode: 
Windows 
Shuidorm mode: 
Wher stattup fair lOê? 
Prog: Mohamed Youssef ۳٦ 


eاCompi‏ التبویب 


تحديد شكل المعالجة ومنة يتم 


WindowsApplicationl = Microsoft Yisual Studio TEK 
FE ER View Pmectl Bild Ûebug DU loo Window Lommunly Hap 
اد د ق >-1 و فو‎ gE 5 | O E i 


WindowsApplicatiaonl  Fomi1.vb [Design] ’ Stari Page 


pp اا‎ 
PPE Bi ouput Dati ™ 


Compile birn Helease" Beme 
Debug Advanced Compile Dpliorë... 


RefereriGes : 1 
plier explici: © plan shricl: O Upliaon cornpare: O 


n nı | Df EL په‎ 
Sluis Condition Notiicatior 
Implicit corryersior | Home اپ‎ 
signing Lake brding; call could fail al run Hime Nore ي‎ 
Seeuily Implicit pe: object assumed Moire ب‎ 
lse of vaniablë priot lo sesignimei Warming په‎ 
bii Funeion Operator wkhout runn Yale | Warring ب‎ 
#ااةأة افعدا غاا‎ 0F 7 warming ب‎ 
Irstarca wariabla ãccessas shared member warming په‎ 
Recursive operalor or properly access 40 USS E اه‎ 
Duplicate or overlapping catch blocks Wang يه ت‎ 
4 | 


مفعل فانة يلزمك بالأعلان عن كل المتغيرات بالمشروع ويفضل ذلك اذا كان هذا Ûخlر Option Explicit‏ -1 


اذا كان هذا الخيار مفعل فانة يلزمك ءءء "0 Opİi‏ - 2 
نوع محدد من البيانات بيانات من نفس النوع اي لو كان لدينا المثال التالي اعطاء أي 


الكود البرمجي 


Dim i As Integer 
Dim s As String 
S "10" 

i = s' This Fails. 
s = "Hello" 

i = s ' This Fails. 


ولو كان الخيار غير مفعل فانة يقوم بتحويل البيانات 
المسندة إلي النوع المراد اذا كانت مناسقة فقط مثلا 


الكود البرمجي 


Dim i As Integer 
Dim s As String 
S "10" 


i = s' This works. 
s = "Hello" 
i = s ' This Fails. 
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ويفضل جعل هذا الخيار مفعل لجعل المعالجة اسرعوتحويل انواع البيانات باستخدام الدوال افضل و لجعل هذة الخيارات مفعلة 
لكل مشاريعك اذهب إلي القائمة وامه] ومنها اخترم هزمه وقم باختيار مoناuامء‏ له اءمزهإم من قائمة العرض الشجري 


ومنة اختر ءااuںهم5‏ ۷/8 وقم بتفعيل الخياران وثم اضغط)ں 


Default propect sethngz: 


Lption E plicit: 
LIption Strict: 


LIption Lompare: 


Binary or Textlڊ‎ aدحي ها الخیار‎ Option compare 


Opitans 


=1: Environment 
` “General 
: Fonts and Lolars 
3: Projects and Solutions 
` <“ General 
YB Defaults 
3. Tent Editar 
Hl Windows Forms Designer 
+1. Device T onls 


. 


[_ | Shor all settings 


وذلك لتحديد نمط معالجة النصوص اعتماد علي البذنري أو علي تحسس حالة الأحرف 
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irl  Lommuriy Help 


ويفضل جعل خيار المعالجة بواسطة راع لأنة اسرع 


التبويب Resources‏ 
ومنة يتم تحديد ملفات تستخدم كمصادر 


o WindowsApplicationl - Microsofl Yisual Studio 


j 


Sart Fage 


A Strings E Add Fesounmee =| } 


E:‏ وا 
Add Eristing Fhe... | ۴‏ 


5R‏ ا اتیگ 


mi Newe T aut File 


۳۸ 


Hull  Ûekbiıg Ûats Toanls 


File Edl Ye Frajeet 
لكل‎ a ات ا ك چ‎ 


WindowsApplicationî | Fomn1, vb [O esigrn] 


Applicalan 
Laompile 
Cabung 
Raferarces 
|۴ E 
Sathings 
Signi 
SEL 


Publish 
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ومن ثم تستطيع التعامل مع الملفات التي اضفتها إلي مشروعك كمصادر بكتابة الأكود البرمجي التالي 
الكود البرمجي 
اسم الريسورس الذي تري د.s٥cں‌0‌ءم‌R Ny.‏ 
فمثلا لو کان لدینا ومع ں‌ه‌وم۴R‏ عبارة عن صورة واسم الصورةإوع 
واردنا عرض الصورة في ×0 6م ں]ء م ما علينا سوي كتابة الأتي 


الكود البرمجي 


PictureBox.Image = My.Resources.Car 


التبویب ہوااطںم 
ومنه يتم نشر المشروع اي تحویله لملٰف مںامS؟S‏ 


e WindowsApplicationê = Microsoft Yisual Studio 
Fe E Yew  Piqerl Biunld Debug Dal lool Windw Lommunly Hep 


POET TET PETE ECL 


WindowsApplicalion2  Foml.vb [Design] ' Start Page 


Application 
ا | ددم‎ 

Compile Publishing Lacalion [web sita, ftp 7 Elia) ا‎ 
[i #biiğ 


Irstalation URL [I different than aboye]: 

ReferERIEES ية‎ ea 
Resouroes Install Mode ard Sellmgs ڪڪ‎ 
J The application is avalable online only 


Sethrugs 

{a The applicati 
Signi 
SES 


a Pubieh Version 


Major Mrmor Build Reremr 
1 1 1 |0 


[¥] dutomalidally inerement teêion wilh #ach publish 


E rra List‏ ا 
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[Bulid] 


تتكون من الأزرار تلك لتي تعمل علي معالجة كلأ من التطبيقات والمشاريع 


f Yisual StudIOo 


| Uala Formal Tools 


LlEan Windows Ãpplizatlaorl 8 1 
Publish WIndows pplication Î O 


سس 
ا F۴‏ 


Ex 


EE Formîl 


-١‏ يقوم بيناء صلضاتك و حفضخ التجدبلات 
آ- يقو م باعادذة بناء صلقانكت صلتف صلضف 
-٣‏ يقوم بجذقف الصلضات الصةقزة 

- يقوم بختج صعالج نر الصسردع 
لتحويلة لصلت: ۴1110ء5 


Debug] 


تحتوي هذه القائمة علي ازرار الأوامر التي تقوم بعملية تنقيح وتصحيح 
الأخطاء البرمجية بالكود البرمجي البرامج 


nnIinqj ¬ Microsoft YIisual SltudIo 


Tools Windows LarmrmuarnIkty Help 


Locals LCtrl+Aalt+y, L 


Break ھےۓ¿ll‎ Ltrl+Break [ BEreakpolints Ltrl+Ãlt+E 


Stop Debuaalinga Ltrlrêlt+Break E uitpuit 
گر + اا + ا۲ا اا‎ 


1 1 1 ا‎ 
ll ll > 


L2ll Stack Ltrl+L 
Threads Ltrl+Alt+H 
YY atch 


0 


E#ceptlonz... Ltrl+Alt+E | A odulazs Ltrl+Alt+ Ll 
Script E #plorer 


Hew Breakpoint ۲ Processes Ctrl lt+Z 
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ٍ Window 
يحتوي علي قائمة فرعية بها الكثير من ادوات تتبع وتصحيح الأخطاء‎ 
Breakpoint Watch,þin 


Continue 
استئناف عملية النذ لتنقيح‎ 


Stop Debugging 
ايقاف عملية التنقيح‎ 


Detach all 
فصل المنقح عن العمليات المرتبطة بة ولكن لأ يقوم بانها تلك العمليات‎ 


Terminate all 
انها أي عملية مرتبطة بالمنقح‎ 


Restart 
ايقاف عملية التنقيح الحالية واعادة تشغيلها من البداية‎ 


Exceptions ٠ 
يقوم بفتح نافذة الأستثنائات حيث يمكننك تحيد نوع الخطاء الذي تريد ان يتعرف المنقح علية‎ 


New Breakpoint 
لأضافة نقطة توقف جديدة‎ 


[Data] 


Yisual Studio 


Uata Formal Tools: Window Loaormmunity Help 


al Show Data Sources ShiftrAlt+D 1 ک‎ — a ا چ س‎ F3 
E FPreyiey Data... O 


Add Hew Data Source...‏ ل 


1- لجرض ناتذثخ صصضذر البيانات التاتا صن خلذلها يحصكنك 
اضاتد قاعدة بياناات د احصكانيدة حصل الربط الحضوكب الحداولي 


2- استجراض بياناات حقوك ج بحداوك تاحدذة البيانات 


3 - كرض صجالج اضاتقة تاعحدذة بیانات 


Add Hew Data Sı 


هذة القائمة تستطيع من خلالها التعامل مع قواعد البيانات 
من اضافة وعرض وربط قواعد البيانات المختلفة 
Access ,Sql,Oracl‏ 
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[Format] 


تحتوي علي ازرار الأوامر التي تقوم بترتيب وتنظيم الأدوات علي الفورم 
واظن ان هذه القائمة لأ تحتاج إلي شرح فاسماء ازرارها تظهر اعمالها 


Fa YindowsApplicationl - Microsoft Yisual Studio 


File Edt Yew Project Build Debug Lata 
وها قك >23 فول‎ 
7 Form1.¥b [D esignl"| Foarrnl . ا‎ 


Formal | Tools 


Irony 
Alan ۴ 


Make Same SIzE F 


Harlzontal Spacing F د‎ || Height 


Lommunily Help 


ga e 5 > r 


E width 


Form Î YWerlical Spacing 


Lenter In Forrn 


Urder 


i 


Lack Controls 


اذا ارذت لحجيت دت صن الذذوات لتكوب حسب 
شگل ادات حصجينة ققح بتحدذيدذ حصية الذذوات الذكي 
رید تحصها وډذلك بضخط علي الزر أ٣ا]‏ حع النقر بالصاو يس 
وقوح بتحديد الذذاة الصراد التحجيح علي اسسابیسټا ټ انقزر لبا 
بالصاويس جحد بكوب التحدذيدذ عليها باللوث الذبيض تد صن القاتحكة 
Both jië| laiaڊ ake Same Size jiîz| Format‏ 


[Tools] 


تحتوي هذة القائمة علي الأوامر التي لأ يتلأئم وضعها في أي قائمة اخري 
وهي التي تستطيع تغيير بيئه تطوير الفيجوال نفسها 


Taols  YYnmdoy LUommunity Help 
ûttach to Process... Ctrleilt+F 


Lonnect lo Dewice... 
Lonnect lo Database... 


Lonnect to Server... 


Lode Snippets Manager... Ltrl+E, Ctrl+B 
Lhoosze Toolbox lterns... 

Add-in Manager... 
Macros 


lIparade Yisual Basic B Lode... 


External Toanls... 

Device Emulator Manager... 
Import and E#port Settings... 
Lustaormize... 


Upktionza... 
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[ Attach To Process 
Attach يقوم بفتح نافدة ربط المنقح مع عملیه تنفد حالیا اختر اي عملیه نم اضخ¡ڊ‎ 


Connect to Device 
يتيح لك هذا الخيار الأتصال مع اداة أو جهاز مثل الهاتف الكفي أو الهواتف الذكيه‎ 
Connect to Pocket PC or Smartphone e or emulators 
وذلك لأختبار البرنامج الذي تصممة من اجلها‎ 


Connect to Database 
يقوم هذا الخيار بفتح نافذة الاتصال مع قاعدة البيانات ومعرفة القواعد المرتبطة‎ 
مسبقا مع السرفر الخاص بربط البيانات‎ 


Code Snippets Manager 
يقوم بفتح نافذة مدير مقاطع الأكواد لأضافة أو ازالة المقاطع وكيفية‎ 
استخدام هذة المقاطع من الأكواد الجاهزة يمنكنك الضغط بالزر الأيمن في شاشة‎ 
Insert Snippetرlيڌخا‎ مۃî الأكود البرمجي‎ 
وستعرض لك الأكواد مقسمة بمجلدات حسب الفئة قم باختيار أي مجلد تريد‎ 
ثم ستعرض اسماء لأكواد الموجود بالمجلد قم بالضغط علي اسم الأكود البرمجى ي الذي تريد‎ 
وسيقوم الفيجوال بيسك باضافتة مباشرتاً‎ 


Choose Toolbox Items 
1٥0٥۱8 يقوم هذا الخيار بفتح نافذة اختيار وحذف الأدوات من×0‎ 
فالأدوات المضافة تلقائيا بعد تذبيت الفيجوال ستديو دوت نت ليست كل الأدوات المتاح‎ 
استخدامها بل يوجد هنالك الكثير من الأدوات التي يمكن اضافتها‎ 


Macros 
يحتوي علي قائمة فرعية تستطيع من خلالها انشا و تعديل أو تنفيذ ميكروا‎ 


External Tools 
۲٥٥١s Ne ںuلا یقوم باضافۂ او حدف زر من‎ 
متلا تستطيع ان تضيف زر يشغل أي برنامج من داخل الفيجوال بيسك‎ 


Device Emulation Manager 


تقوم بفتح نافذة ادارة الأجهزة تشغيلها أو اغلأقها والأتصال بها 


Import/Export Settings 
|5 يقوم هذا الخيار بفتح معالج حفظ أو استعادة اعدادات بيئة التطويرع‎ 


Customize 
يقوم هذا الزر بفتح نافذة ماص ه]وں التي تستطيع من خلالها تعديل ازرار القوائم‎ 
من اضافة وحذف وتعديل مظهر القوائم من اضافة القوائم الفرعية‎ 
ويمكنك اضافة الأزرار بواسطة السحب والأفلات في اي قائمة تريد‎ 


Options 
يقوم بفتح نافذة تستطيع من خلالها تحديد الخيارات الخاصة ببيئة التطوي‎ 
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[ Window ] 


تحتوي هذة القائمة علي الأوامر التي تتحكم في نوافذ الفيجوال بسيك دوت نت 


Lomrmunity Help 


Mey Horizontal I ab Group 


Mewy Wertical Tab Group 
Llose ږAll‎ Documents 


Reset Window Layout 


1 Formi.Yb [Deslan] 
û Forml.yb 
3 Start Faqe 
WIndows... 


Dockable, Floating, Tabbed Document 
تتعامل مع النوافذ الثانوية مثل‎ 
Toolbox, Solution Explorer, 
بتغيير طريقة اظهار النافذة أي تكون ظاهرة بشكل عائم أو بشكل ثابت‎ 
أو النقر المزدوج علي شريط عنوان النافذ لجعلها عائمة أو تكرار النقر لتثبيتها‎ 
والأن قم بالنقر المزدوج علي شريط العنوان لأي نافذة ثانوية‎ 
كي تكون بشكل عائم ثم بواسطة الضغط المستمر بالمأوس‎ 
علي شريط العنوان وسحب النافذة سوف تظهر لك‎ 
مقابض في شاشة الفيجوال تستطيع بواسطة هذة المقابض‎ 
تثبيت النافذة في أي مکان تربد‎ 


[ Auto Hide 
تقوم بخفاء بخفاء تلقائي للنافذة الثانوية وتظهر عند مرور المأاوس عليها‎ 
Hide 
ز٥س يقوم هذا الخيار باغلاق النافذة الثانوية و نطب اظهارها مره انيه من القائمة‎ 
أو من خلال الضغط علي اختصار اظهارها من شريط الأختصارات‎ 


Auto Hide All 
يقوم باخفاء کل النوافك الثانوية الظاهرة‎ 
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[ New Horizontal Tab Group 
يقوم هذا الخيار بعرض اكثر من محرر في وقت واحد علي الشكل الأفقي‎ 
أي اذا كانت تعمل علي محررالتصميم للمشروع وتريد ايضا العمل علي محرر الأكود البرمجي‎ 
قم بالضغط علي هذا الخيار وسيكون الشكل كما هو موضح بالصورة‎ 


Te YY indowsApplicationl - Microsoft Yisual Studio 
File Edl Yew Project  Buld Debug Lata Formal Tools Windom Lommunily Help 
Le SE H- RAL da BLE 2 | þi lg S2 [3 © 
اا‎ Form1.¥b [Design] Start Page 


|# | 


yl 4arab 


ا 


7 Forml. hî 


س 


___ # FomlEvens] 1# [Form Events] #lad #lad يه‎ 
Public Class Forml 3 
Private Sub Forml Load(EyYal sender As System. Vb ject, _ 
EyYal E A3 System. EvEeEnNnTAFS23] Handles HyEBa3se . Load 3 
Hsq{Box ("YEFLELE THE BEST WEB SITE"} اف‎ 

End Sub 

End Llass 

111 SM 


۸ 


New Vertical Tab Group 


يقوم هذا الخيار بعرض اكثر من محرر في وقت واحد علي الشكل العموديأي اذا كانت تعمل علي محررالتصميم للمشروع وتريد 
ايضا العمل علي محرر الأكود البرمجي قوم بالضغط علي هذا الخيار وسيكون الشكل كما هو موضح بالصورة 
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WindowsApplicatıonl - Microsoft Yısual StudIo 


Filê Edl Yiw Pisê Bid Dêëbiiğ DÛãalê Tolê Window Lommianiy Hêl 
RSH RIM BRL Sr Cp u a E CE e | Hl NF Hd 3F [Û 21 
 Forml.vb [Design]" Stat Pager | > × | Forml.¥b" 
E] Public Class Formil 
PFivwatê Sib Form1 Löad( ByVal saender 
Ais Syatem. Object, 


Eyal e Ais System. EventAr 
HsgBox | "VTEOSIALRAE THE BEST UEB SITE"] 

٣ Enda 3uۈb‎ 

- Fond LJIaz=s 


2 


Close All Documents 
يقوم هذا الزر باغلاق كافة المحررات المفتوحة‎ 


Reset Window Layout 
يقوم باعادة النافذة للوضع الأفتراضي لها‎ 


Windows 
يقوم بفتح نافدة تستطيع منها تحديدة أو إغلاق اي محرر مفتوح‎ 
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[Community] 


Loarmriuniky | Help 


ıl Ask a Question 

heck Question Status‏ ر 

® Send Feedback 
Developer Lenker 
_odezone Zomrnuniky 
Partner Products Latalag 


_ormmunity Search ۴ 


تحتوي علي الأوامر التي تساعدك في الأرتباط مع مجتمع البرمجة بالفيجوال بيسك 
بحيث يمكنك ان تسئل وتقوم بالبحث عن اجابة أو امثلة وهذة الأوامر مرتبطة 
بصفحات میکروسوفت كما يمكdi‏ jزlıرة MSDN Community Center‏ 
من خلال هذا الرابط 


[Help] 

Help 

WÎ How Do1I Ltrl+F1 
A Search ctrl+Alt+E3 
df Contents Ltrl+Alt+F1 
Index trl+Alt+FZ 
F3 Help FaYorites w_Erl+Alt+F 
@| Dynamic Help ctrl+Aalt+F4 


| [Eq Index Results Shift +Alt+F2 
_ustomer Feedback Options... 
Register Product, 
heck For Ipdates 
ya Technical Support 


About Microsoft Yisual SEJdio 


ر ا — 


تحتوي علي الأوامر المالوفة الخاصة بالمساعدة والأتصال بموقع الشركة والتعرف علي كيفية استخدام اللغة وخيار العثور 
علي التحديتات اللازمة للبرنامج وسوف نتاولها بالتفصيل في الفصل السادس من هذا الكتاب 
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الاد وات لى النیجوال بسك دوت نت ۲۰۰۵ 


الأدوات : هي عبارة عن عناصر برمجية لها مهام معينة تاخذ اشكال رسومية ولكل اداة عملها الخاص 
*تصنف الأدوات إلي صنفين: 
Control‏ 


وهو العنصر البرمجي الذي يأخذ شكل رسومي معين ويوضع علي الفورم اثنا ء تصميم البرنامج ويقوم بتادية مهمة معينة مثل 
Button , Textbox , Label‏ ولكل اه1۲,ه٥‏ خصائص ووظائف تميزة عن غيرة 


Component 

وهو شبیه بال êControlيمl‏ عدا: 

لايظهر في وقت التنفيذ اي وقت الاستعمال 

يظهر اثنا تصميم البرنامج علي شريط خاص به أسفل الفورم علي شكل ايقونة 

ولكن بالرغم من ذلك يمكن ان يظهر علي الفورم اثناء التصمیم مثل ں ٥م‏ أو وقت التنفیذ مJiلog‌OpenFileDial‏ 
*التعامل مع الأدوات. 


الأدوات تساعد المبرمج اثناء تصميمة برنامج بقدر كبير فتقوم باختصار الكثير من الأكواد الصعبة والطويلة ولكل اداة من 
ادوات الفيجوال بيسك دوت نت غرض معين ومهمة معينة وتقوم كل اداة بعمل مختلف عن الأداة الأخري 


Taûlbûk 


ل 
Bz‏ 
2 

ر 


` Common Controls 
Menus & Toolbars 
Dala 

Components 
Printing 

Dialogs 

General 


i EI EÛ Fl FF Hl FÎ FEF 
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انشاء الأدوات. 


*يمكنك اضافة اي اداة إلي برنامجك باحدي هذة الطرق : النقر المزدوج علي الأداة المراد اضافتهالسحب والأفلات 
باستخدام المأوسالنقر نقرة واحدة علي الأداة المراد اضافتها وثمالنقر نقرة واحدة علي الفورم وسيتم اضافتها 


*ولكن لو اردنا انشاء مجموعة كبيرة من الأدواة كعمل برنامج حاسبة بة ازرار عديدة مثلافاءن الطرق السابقة 
لأضافة الأزرار ستكون متعبة قليلأفما هو الحل ياتري في رايك ؟الحل هو الضغط المتواصل علي مفتاح ٥۲1‏ ثم النقر 
نقرة واحدة باستخدام المأوس علي الأداة التي تريد اضافه عددأً منها ثم النقر علي الفورم ستلاحظ في كل مرة تقو 
بها بالنقر علي الفورم اضافة الأداة مرة جديدة وباسم جديدوعندما تريد الأنتهاء من اضافة الأداة فما عليك سويايقاف 
الضغط علي مفتاح ٥]‏ أوالضغط علي ايقونة موشر المأوس التي في اعلي الأدوات. 


تجميع الأدوات داخل حاوية. 
هنالك أدوات عملها الأساسي هو احتوي ادوات اخري بداخلها مثل 
TabControl, GroupBox, Panel,‏ 


وباستخدامها تستطيع تجميع عدد من الأدوات في حاوية واحدة لغرض نقل وتحريك أو اخفاء واظهار تلك الأدوات أو 
لأغاض اخري. المهم في لامر اننا باستخدام حأويات الأدوات نستطيع ان نتعامل مع مجموعةمن الأدوات ككتلة واحدة 


هنالك عدة طرق لتضع الأدوات داخل حاوية container‏ وذلك بسحب الأداة الموجود علي الفورم إلي داخل 
container‏ أو بتحديد ال اهاهاه الذي قمت باضافتة مسبقا إلي الفورمثم و من قائمة الأدوات تقوم بالنقر 
المزدوج علي الأداة التي تريد ان تضيفها إلي "٥۲‏ ههه وستضاف بداخله مباشراً وليس علي الفورم أو بواسطة 
السحب والأفلات من قائمة الأدوات إلي داخل ال. مه٢‏ هء أو بواسطة القص واللصق من علي الفورم إلي داخل ال 
container .‏ 


*انشاء الأدوات في وقت التنفيذ: مصأآ Ru”‏ 


غالبا نقوم بانشاء الأدوات علي الفورم في وقت تصميم البرنامج عن طريق اضافتها من قائمة×٥ ٣٠٥۱8‏ ولكن 
وبالرغم من ذلك فاننا قي بعص الاحيان قد نحتاج لاإنشاء الإدوات في وقت تنفيذالبرنامج Run Time‏ اي انشاء الدوات 
والأحداث الخاصة بها عن طريق الأكود البرمجي 


ولكن قد نتسائل ما الدافع الذي يجعلنا ننشئ الأدوات بواسطة 
الاكود البرمجي طالما اننا نستطيع انشائها في وقت تصميم البرنامج ؟ 


الجواب انك في بعض الأحيان قد تحتاج لعمل برنامج يملك واجهات مختلفة يخدم مستخدمين مختلفين .المستخدمين 
مختلفين في مهاراتهم أو يحتاجون لأدوات مختلفة تبعا لاختلاف اعمالهم ومتطلباتهم .أو انك لأ تعلم ماذا سيتطلب 
برنامجك من ادوات لعرض أو ادخال البيانات لأن ذلك متوقف علي حاجيات المستخدم للبرنامج . أي انك سوف تحتاج 
إلي انشاء ادوات في وقت التنفيذ. م٣٣‏ مں# الأن سوف نتعرف علي كيفية انشاء الأدوات وقت التنفيذ: مصأ۲آ Ru‏ 
انظر إلي هذا الأكود البرمجي 


الكود البرمجي 


Dim IbIHi As New Label 
IbIHi.SetBounds (50, 50, 70,70) 


IbIHi.Text=""Hello World" 
Me.Controls. Add (IbIHi) 


بهذا الأكود البرمجي نستطيع انشاء امطج 1 علي الفورم في وقت تنفيذ البرنامج وألأن نأتي لشرح الأكود البرمجي في السطر 
الأول قمنا بالأعلان عن المتغير İ١۴۸١ط|‏ علي انة من النوع . Label‏ في السطر الثاني قمنا بتحدید احداثیات ۳اا علي الفورم 
بواسطة الخاصية . ول ںه8Bءه5‏ في السطر الثالث قمنا بتغيير الخاصية ٣٠×‏ ليكون الأسم الظاهر لل إمطج اهو لااWo‏ 0اامH‏ 
.ثم في السطر الرابع والأخير قمنا باضافة ٨1ط‏ إلي الأدوات التابعة للفورم الحالي بواسطة الخاصيه له المترفعة من 
الخاصية واهإاہه التابعة للفورم . ولكن لم نحتاج لعمل حدث تابع للأداة امطه] لأننا في الأغلب نستخدمها لعرض معلومات 
علي الفورم ولكن هنالك ادوات اخري مثل ٥٥ں‏ لأ نستطيع التعامل معها إلي بواسطة الأحداث التابعة لها كحدث الضغط 
عليها مثلا . والأن سوف نتعرف علي كيفية انشاء اداة في وقت تنفيذ البرنامج مع انشاء احداث تابعة لها وأولاً يجب ان 
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نعرف اننا اذا اردنا الأعلان عن متغير علي انة من نوع اداة ما بيجب ان يكون الأعلان مبتدا بالكلمة المحجوزة With Eve ۸s‏ 
أي اننا نصرح عن متغير من نوع اداة وله احداثة التابعة له مثلا نكتب 


الكود البرمجي: 
Dim WithEvents btnHi As New Button‏ 


هنا اعلنا عن المتغير ٨۳ط‏ انة من النوع Button‏ واا اردنا الوصول الي احداثة كلما علينا هوالدخول إلي شاشة الأكود 


البرمجي تم ومن قائمة سرد العناصر الموجودة بالفورم الحالي م٣a×١‏ ‰5هاع ثم تحديد الحدث المراد من قائمة سرد احداث 
العناصر 


eth od Name‏ انظر إلي الصورة التالية 


e YindowsApplicationl - Microsoft Yisual Studio 


File Edt Yew Propectl Buld Debug Uala Iools Window Lomrmurnity Help 


ا کک 8 ا د اک اعا چ ھی 


Form1.vt vb E Yb [Design] | 


- 8 [6G ener al] 


lê Formî 


9 (Form E werts| 


WithEZENES prtnHi1i A3 Button 


End LIas33 


الأن قم بفتح مشروع جديد وقم في منطقة التصريحات العامة بكتابة هذا التصريح 


الكود البرمجي 
Dim WithEvents btnHi As Button‏ 


تم قم قائمة سرد العناصر م۳ ه. ءءه|ا باختيار العنصر ٨1ط‏ كما توضح الصورة السابقة ثم قم باختيار الحدث الذي تريدة 
لهذا العنصر من قائمة سرد احداث العنصر انظر الصورة التالية 
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أي اننا بمجرد الأعلان عن متغير انة من نوع اداة فان الفيجوال يقوم بانشاء احداث لذلك المتغير ويتاعمل معة وكانة عنصر 
موجود علي الفورم . ونهاية لفهم ما سبق نقوم بهذا المثال قم بانشاء مشروع جديد قم بكتابة هذا الأكود البرمجي في منطة 
التصريحات العامة 

Buon ةغlضاب pءã îWithEvents btnHi As Button‏ علي الفورم وقم بالنقر المزدوج علية لتدخل إلي شاشة الأكود 
البرمجي في الحدث )ءا _1١٥]†ںع‏ قم بكتابة الأكود البرمجي التالي 


الكود البرمجي 


btnHi = New Button 
btnHi.SetBounds(96, 50, 75, 23) 


btnHi.Text = "Say Hi" 
Me.Controls. Add(btnHi) 


ثم قم بعمل حدث ءزاع للعنصر ١٨ط‏ كما تعلما واكتب بداخلة 


الكود البرمجي 


MessageBox.Show(“Hi Man”) 
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والأن شغل البرنامج وقم بالضغط علي الزر 1٥٥٤اںB‏ ستلاحظ ظھور ۸٥]ااںع‏ جديد علي الفور لة الأسم ۳۸ رھ اذا قمت 
بالضغط عليه سوف تظهر لك رسالهھ مکتوب بھا ہج i‏ 


تكلمنا في الدرس السابق عن الأدوات وتعلمنا كيفية انشائها علي الفورم في وقت التصميم أو في تنفيذ البرنامج ولكن بقي 
ملاحظة تخص انشاء الأدوات في وقت التنفيذ وهي كيفية حذف اداة ما في وقت التنفيذ ثم سننتقل بعدها إلي خصائص الأدوات. 


حذف الأدوات وقت التنفيذ: 


مثلا لو كان لدينا هع الأسم البرمجي له ١٨ط‏ ونريد حذفة من علي الفورم في وقت تنفيذ البرنامج كلما علينا هو كتابة 
الأكود البرمجي التالي في زر امر حذف ذلك ال ہ )ا ںم 


الكود البرمجي 


Me.Controls.Remove(btnHi) 
btnHi = Nothing 


سيقوم ذلك الأكود البرمجي بحذف الزر ٨1ط‏ من علي فورم البرنامج حتي ولو تم انشاء ذلك إل ١٥ں‏ في وقت تصميم 
البرنامج أو في وقت التنفيذ ولكن حذف أداة من علي فورم البرنامج إثناء تشغيله لأ يعني انة تم حذف أحداث تلك الأداة. 


خصائص الأدوات وكيفية التعامل معها: 


الخاصية : هي قيمة أو بعض القيم التابعة لأداة التحكم والتي تتحكم في عمل أو مظهر الأداة . مثلا اداة التحكم ٣٠×16‏ تمتلك 
الخاصية مصھN‏ وهي التي تتحكم في اسم الأداة البرمجى الذي بستخدمة المبرمج ج اثناء كتابة البرنامج وكذلك الخاصية 1٥×‏ 


وهذة الخاصية هي التي تتحكم في الكتابة التي ا في ۲٠×180×‏ وتوجد ايضاء الخاصية هام٥ 8a٥)‏ وهي التي تتحكم في 
لون الخلفية وهكذا. 


لكل اداة خصائص عديدة ة وتتشابة معظم الأدواة في الكثير من خصائصها ولكن هنالك خصائص لأا توجد الأ في نوع محدد من 
الأدوات مثلا الأداة ImageList‏ تمتلك الخاصية Images‏ التي تستطیع باستخدامها من اختيار العدد الذي تريد من الصور التي 
سوف تخزنها هذة الأداة لاستخدام ها کایقونات متلا مع ادوات اخري مثل استخامها مع اداة العرض الشجري. ۲۲٥٤٥۷1٥ W‏ 


لتعدیل خصائص أي اداة من ادوات التحكم في وقت تصميم برنامجك يجب أولا ان تقوم بفتح نافذة الخصانص وتستطيع فتحها 
من القائمة سه۷ واختيار وsسمهہاW۷‏ ءءنا۲ممهإم أو بالضغط علي المفتاح ۴4 من لوحه المفاتيح . بعد فتح نافدة الخصائص 
يبقي ان نحدد الأداة التي نريد تعديل خصائصها وذلك يتم بطريقتين الأولي باختيار اسم الأداة من اعلي نافذة الخصائص أو 
بالنقر عليها نقرة واحدة باستخدام المأوس فتظهر لنا جمیع خصائص تلك الأداة في نافذة الخصائصضص بعدها نقوم 

بالنقر بالمأوس امام اسم الخاصية المراد تغييرها وكتابة أو اختيار القيمة الجديدة لها. 
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هنالك انواع كثيرة للخصائص فهنالك الخصائص المركبة من اكثر من قيمة والخصائص المحصورة بين قيم محددة وثابتة كذلك 
هنالك الخصائص المجمعة كمجموعة وسوف نستعرض كل نوع من انواع الخصائص علي حدة كي نفهم كيفية التعامل معها. 


١‏ الخصائضص المركبة. 


بعض من الخصائص تمتلك قيم مركبة مثلا الخاصية ٥١‏ ناء ه] تتكون من الحداثيان ۷ همه × والخاصية ماك تتكون من 
القیمتین وم width and‏ والخاصیة م۴ متلا تتکون من القیم وsومہ‏ لاط ,مآء ,meھہ 1s‏ ہfوغیرھا‏ من خصائص 
الخطوط أي هنالك خصائص تتكون من اكثر من قيمة ونلأحظ في الصورة السابقة ان هنالك خصائص امامها علامة الزائد (+) 
تلك هي الخصائص المركبة فلوا قمت بالنقر علي هذة العلامة سوف تظهر لك قيم هذة الخاصية. 


۲ الخصائص المحصورة: 


هي الخصائص التي تكون قيمها محصورة ومحددة وتكون قيمها علي شكل قائمة سرد بها القيم الممكن اعطائها للخاصيه 
ومثال علي هذة الخصائص الخاصية ءاطاوا۷ فهدة الخاصية تمتلك احدي القیمتین ٥ا۴۵‏ ۸۵ھ مں٣٦‏ ولا يمكنك اعطائھا قیم 
اخري الأ اذا كانت القيمالأخري مسأوية للقيم الحالية مثلا القيمة 1- =مں۲۲ والقيمة. 0 =مءام۴ 


۳- الخصائص المجمعة. 


هنالك خصائص تتكون قيمها من مجموعة من القيم أو العناصر مثلا أداة التحكم ×0 18ء[ تمتلكالخاصية ء.٠]!]‏ التي تتكون 

قيمتها من مجموعة من العناصر تلك التي تقوم اداة ×ه18ءزا بعرضعاأو مثل الخاصية اءأاموهص| فيمها تتكون من مجموعة 
من الصور يتم عرضها بأدوات أخريكذلك هنالك خصائص قيمها تتطلب وجود أداة أخري فمثلا لعمل صور باعلي عناصر الأداة 
اabContr0ايجب‏ ان توجد الأداة اوiاموهص!|‏ واعطاء الخاصية وموهم!| التابعة لها مجموعة من الصور كي نقوم بعرضعا 
كايقونات في عناوين . ا۲ا" طه٣‏ وسوف نقوم بمثال لعمل ذلك. 
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o۴۳ E_Mail: Mohamed.yoyo@gmail.com 


مثال وضع الصور ڊgliaڍjù: TabControl‏ 


قم بفتح مشروع جديد بالفيجوال بيسك دوت نت ثم قم باضافة هذة الأدوات إلي فورم البرنامج الأداة امأ٣‏ ه٥‏ طج٣‏ وعدل 
الخاصية مه" لتكون م×٤طه۲‏ والأداةاو|اموه".| وعدل الخاصية مه لتكون م×٤طه٣اءاوص!‏ ثم قم بالنقر نقرة واحدة 
عد ImgIstT ab Exp5|‏ فتظهر لك خصائصها بنافذة الألخصائصضص ومنها قم بالنقرامام الخاصية Images‏ وستظهر لك نافدة 
محرر اضافة الصور التابع للأداة 


Images Collection Editor 


eEriberz: 
Haz= LCOROMOICD 
ES LLDRIYE.ICDU 


ولو تلأحظ الصورة فانة يوجد صورتين تم اضافتهما مسبقا فقم انت الأنباختيار صورتين بواسطة الزر لهه ثم بعد ذلك اضغط 
)0 عندها سيغلق محرراضافة الصور وستعود إلي وضع تصميم البرنامج الأن قم بتحديد الأداةم×٤طه]‏ لتظهر خصائصها 
بنافذة الخصائص والأن قم بالنقر امام الخاصية اوا اموهم! التابعة للأداة مجعطه٣‏ وقم باختيار الأداةم×عطaاImgIst‏ 


Properties 
TabErp System. YIindowys. Forrmnz. TabControl 


LEursar Oefault 

Dock ore 

Draw ode Iorrnaخl‎ 

Enablad Trym 

Formt Tahoma. Bpt 

enerateîerm TI rE 

HotT rack Falsë 

lraîêLIzE ImglstT abE Hp || 
Ime ode 
Iter lzë IrmglstT abE#p 

Location 2 

Locked Falsë 

FAargir 3 3 3 

AamirnuırmSizëê ÛU, ÛU 

AinimunSizë ÛU, U 

FAodiliers Friern 

FA ultilirız ل۴‎ 


3 


3 


3 #8 


ImaqgelL ist 
The ImaaeLiIst obje 
ImnaqEez. 


والأن قم بالنقر امام الخاصية وموه ٥‏ طه" التابعة للأداة م×عطه٣‏ وستظهر لك نافذة تعديل واضافة التاب (وطج٣)‏ 
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س ے - سے —— 
a.‏ 


?2 صن شذة النافذة قم غير | 


حصاتص التاب الصحدد | 


ااا ااا الا | اا ا 


Modifiers 
El Focus 
LausesYaldalion Tê 
El Layout 
اداع 5اك‎ False 
E dutoSerolMargin Û, Û 
E AutoSerolMinSize O, Û 
CCE 
3. 3 3 3 
r 3 


Friend 


E Padding 


Imagek.ey | 
ToolTipT est 


1 E Margin 


us SS‏ ¬ ا 
٣‏ 
E.‏ 


صن شذة النافذاة حددذ التاب لو0 ا 


pe ا ق‎ i | 
= Fa ت تسا‎ 1. L ل ا ا‎ | 
mR a A Eh n a E a 1 


3 TabPage1 
1 TabFagêd 


ب 
یع پا پار صورة صل صور 
ImageList‏ 
لل سد لطلالب اصاد 
اللاا اوتا طهر اصاع 


= انا‎ m= | 


لحذف تاب 


دت 


ویجب ان تعرف ان الصفحات أو ما يعرف بالتاب (وطه٣)‏ المكونة للأداة م×عطه٣‏ تعتبر ادوات داخلية لها خصائصها المرتكزة 
علي خصائص الاداة الرئيسيه وهي اهإا ه٥‏ طج1 ويمكنك اضافه العدد الدي تريد من التاب من خلال الزر هه الموجود 
اسفل نافذة محرر اضافة وتعديل التاب طج٣‏ وفي النهاية سوف يظهر البرنامج بهذا الشكل 


TabPagez‏ ن 
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o0 


Hl Form-TabExmpl 


َ a TabPagëe1 
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مصفوفة الأدوات 


في الفيجوال بيسك ٠‏ كانت هنالك ميزة جميلة ومفيدة وهي المقدرة علي عمل مصفوفة من الأدواتومصفوفة الأدوات عبارة 
عن مصفوفة من اداة معينة ڊ بحيث تتشارك نفس الأحداث وايضا لها نفس الأسم ونستطيع التمييز بينها بواسطة ×ملہ| الممیز 


وايضا هو الحال في 2005 ۷6.٤۲‏ فان هذة الميزة باقية ولكن مع بعض الاختلاف في كيفية انشاء مصفوفة الأدوات عن 
الفيجوال بيسك .١‏ 


ماهي الفائدة من مصفوفة الأدوات وما الفائدة منها? سوال قد يدور في عقول الكثير وساجيب علية بالمثال التالي 
تصور لو انك اردت القيام بعمل حاسبة تتكون من الكثير من الأزرار فانك بالتالي سوف د SE i ARE‏ 


الحاسبة فلو دخلنا إلي شاشة الأكود البرمجي ماذا سنشاهد منظر غير جيد من تراكم الأكود البرمجي وعدم د تنظيمة ولكن ما 
رائيك لو اختصرت كل احداث الأزرار بحدث واحد فقط هذا شئ غاية في الروعة ويقلل الجهد ويزيد التنظيم هذا صحيح. 


والأن لنقوم بعمل المثال عمليا: 

قم باضافة ۲۲0۸ل 8B‏ إلي فورم وقم بتسمیت bin Num‏ ثم قم بانشاء حدث لة بالضغط علية دبل كلك بعد انشاء الحدث ادخل 
إلي شاشة التصميم وقوم ڊ بنسخ الزر ولصقة ٩-۰‏ اي عشرة ة ازرار ثم قم بالضغط دبل كليك علي اي زر من الأزرار ستدخل 
بذلك الي شاشة الأكود ارم وستلاحظ اضافة اسم ذلك الزر الي جانب حدث الزر nہ‏ ں۸ ہط والان قم بالضغط دبل كلك 
علي كل الأزرار كي يضاف اسمائهن للحدث والأن كيف سنميز كل زر نظغط علية أولاً قم باعادة تغيير الخاصية 

Text‏ للأزرار لتكون الأعداد من ٠-٠‏ وقم باضافة ×هط×ه إلي الفور واجعل اسمة سعا»] ثم قم بكتابة هذا الأكود 
البرمجي في انحدث bin Num.Click‏ 


Anchor and Dock jlتيصاخlا‎ 


الخاصيتان )م0 له امطعمA‏ تعملأن جعل الأداة تقوم تلقائيا بتغيير حجمها وموضعها تبعأً لحجم الفورم الموضوعة علية 
الخاصية ۲ء۸ تحدد أي حد من حدود الأداة يجب ان يبقي ثابتا واي حد يجب ان يزيد عن حجمة الحالي تبعا لحجم الفورم 
الموضوعة علية 


ولأ توجد الخاصية هام۸ الأ مع الأدوات التي تظهر علي الفورم في وقت التنفیذ منل ءا , ۲٥×18 ٥>‏ , ٣٥†اںB‏ وتملك هذ 
الأدوات اربع حدود هي اوا ,اما ,صهاامB‏ ,م٥۲‏ و تحسب قيمة هذة الحدود بالنسبة للفورم 
بالباسيكل (ام×ام) والقيمة الأفتراضية لهذة الخاصية هي اا ,مه7 


و في الأصدار السادس من الفيجوال بيسك لو اردنا مثلا عمل محرر نصوص مثل لهم عه" فاننا سوف نحتاج لكتابة الكود 
البرمجي يقوم علي تغيير حجم ×ه ٣٠×16‏ المستخدم للكتابة تبعا لحجم الفورم الموضوع علية كي يتلائم شكل البرنامج وكذلك 
الحال لو اردنا عمل مستعرض انترنت 


E O O OT TT U 
بالشكل الذي نريد ان تكون علية عند تغيير حجم الفورم تم نقوم بتحديد حدود الأداة التي نريدها ان تتغير تلقائيا تبعا لتغير حجم‎ 
الفورم‎ 


سنقوم بعمل مثال لتتضح الفكرة قم بانشاء مشروع جديد بالفيجوال بيسك ۲٠٠٠١‏ ثم قم باضافة الأداة > 8×ه إلي الفورم 


وتغيير الخاصية هااا لتصبح م٠‏ وهي الخاصية التي تعمل علي ظهور اكثر من سطر بالأداة بوقت واحد وستظهر بعدها 
مقابض تغيير حجم الأداة ثم اجعل حجم الأداه علي الفورم كما بالصورة 
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HE Forml 


ثم نقوم بتغيير قيمة الخاصية ماع۸ بحيث نقوم بتحديد جميع حدود الأداة ۲٥×18‏ 
وذلك بالنقر بالمأوس علي الحد الذي ذرید اختیاره انظر الصورة 


Properties I F#*K 


TextBoxl System. windows. Forms. TexlBo# ” 


NENE 


| 2ا 

[DataBindiraz] س‎ 
[Hare] TextBox] 
AzzeptsRekurn False 
Accepts ab False 
ûAccesslbleDescriptal I 
ûccesslbleH arme 
ûccesslbleR ole Default 
Allow Drap False 

Top. Left ېه‎ 

kop 
24o 
4-o pl 
Back Lolar 


Anchor 


Defines the edges of lhe contalner lo which ã 
certaln cortrol Is bound. Wher ã control I& ãN... 


بعد ان نقوم بتحديد جميع حدود الأداة الأربع نقوم الأن بتشغيل البرنامج 
ونعمل علي تغيير حجم الفورم ستلاحظ ان الأداة >ه8»×٠٠‏ يتغير حجمها تبعا لتغير حجم الفورموالأن لنقم بمثال اخر قم باضافة 
8u‏ إلي الفورم وقم بوضعه الزاويه العليا من الجهه اليمني علي الفورم 
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HE Forml 


__ Bukttonl 


ثم قم بجعل قيمة الخاصية مطإءمA‏ تساوي ×0٥‏ 


أي قم بالغاء تحديد كل حدود الأداة وقم بتشغيل البرنامج وتغيير حجم الفورم ستلاحظ ان الأداة تعمد إلي الأنتقال إلي قرب 
منتصف الفورم والأن قم بایقاف البرنامج وتغییر الخاصیۂ ٣م٣إءہ۸‏ لل ٥٥ں‏ لتكون قيمتها تساوي وا ,مه۲ وهو اننا 
حدد ثم قم بتشغیل البرنامج وتغییر حجم الفورم ستلاحظ ثبات ال ٣٤ں‏ في الزأوية العليا من الجهة اليمني مهما تغير حجم 
الفورم وذلك لأننا قمنا بتثبیت حدود الأداۃ ۸۲٣وا‏ ,م٥٣‏ بواسطة الخاصیة فکلما قمنا بتغییر حجم الفورم فان ال ٣٤ں‏ يعمد 
إلي الأنتقال إلي تلك الجهة المثبتة حدودة عليها كذلك يمكننا تغيير موضع الأدوات في وقت تنفيذ البرنامج مثلا قم باضافة 
Butt"‏ الي الفورم وقم بوضعة باي مكان ثم قم باضافة هذا الأكود البرمجي إلي الحدثلaها_٣۳١٥۴‏ 


Button1.Location = New Point(Me.ClientRectangle.Width -Button1.Width, Me.ClientRectangle.Height - 
Button1.Height) 
Button1.Anchor = AnchorStyles.Bottom Or AnchorStyles.Right 


والأن لنقم بمثال اخير قم باضاف ثلأثة >ه ٣٠×18‏ علي الفورم ثم قم بجعل شكلها علي الفورم كما ما توضح الصورة 
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ثم قم بتغيير الخاصية ه٣٥١۸‏ للأول لتكون قيمتها مه۲ والقيمة للثاني ٥ه"‏ والقيمة للثالث م ٥))ه6‏ 
تم كم بن بتشغيل البرنامج وتغيير حجم الفورم وستلاحظ ان الادوات يتلائم موضعها علي الفورم مع تغيير حجمه 


الخاصية kعD0‏ 


تقوم بتثبت موضع الأداة في احد جوائب الفورم أو الحاوية التي هي عليها متلا لو قمت بتغيير الخاصية )مم5 لتساوي Top‏ 
لأداۃ مثل ٥ں‏ فان الأداة ستنتقل ستنتقل إلي اعلي الفورم وستتمدد جوانبها لتصل للجانبين وا & Le‏ واذا قمنا بتغییر حجم 
الفورم فاءن الأداة ستلاأزم موضعها وتحتفضل بارتفاعها وستتمد جوانبها تبعا لتغير عرض الفورم هذا ما يشابة سلوك الأداة 
7۲ آونستطیع القيام بذلك ایضا بوضع الاأداۃة ٣]uںB‏ في اعلي الفورم وتغيير الخاصية ۲مطءہ۸ له لتصبح ,اما ,مہ7 
اhواRيمكنك‏ تغيير الخاصيه Top, Bottom, Left, Right, Fill, or None يوlصتl D0)‏ 

والخاصية أ٣‏ تقوم بجعل حجم الأداة بملئ الفورم التي هي علية أو الحاوية التي د تحتويها ولكن السؤال ماذا لو كان لدينا اكثر 
م علي الفورم قمنا بتغییر قیم الخاصية )مم لها باستثنا القيمة None‏ اي اداة ستنفد قيمتها أولاً انا الفورم أو الأداة 
ستقوم بترتيب الادوات بحسب stacking order‏ التابع للادوات أو ما يسمي Z-order‏ الاداة التي تم وصع القيمه لها أولا هي 
التي ستاخذ موضعها أولاأ فالتالي والتالي. 

سوف نقوم بمثال للتعرف علي هذة الخاصية اكثر 


مثال : قم بوضع اربع ٠٠×18 ٥×‏ علي الفورم وغير الخاصية "٥‏ )ا للكل لتساوي مں] واجعل احجامهن وموضعهن علي 
الفورم كما بالصورة 


المخلب الجار 7ج-vb4arab EE‏ 


والأن قم بتغيير الخاصية )عه بالترتيب للكل كما يلي 
الأول : اعطيها القيمة وا 

الثاني : اعطيها القيمة Top‏ 

الثالث : اعطيها القيمة Bottom‏ 

الرابع : اعطيها القيمة ١ز۴‏ 
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وسنکون بعد ذلك کما بالصورڈ 


المخلب الجار 7ج-vb4arab E‏ 


الثاني 
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أنشاء مشروع جديد في بيئة الدوت نت 


تعالوا نتعلم معا كيف ننشئ مشروع جديد في بيئة الدوت نت' 


E NS orcas ol A + ا أ‎ 

إن تنشا المشاريع في بيئة الدوت نت وكيف يتم ذلك 

من الفرو قات الأساسية بين بيئتي فيجوال بيسك 1 و بيئة الدوث نث أنه بمجرد ضغطك على زر 
موافق عند ٳئشاء مشرو ع جديد في بيئۀ الدوٽ نٽ فٳن فيجوال سٽوديو دوٽ نٽ يقوم بائشاء كل 
الملفات و نخزينها فى مجلد بالاسم الذى اخثرنه وفى المكان الذى اخترنه. 


عند إنشاء مشرو ع جديد من نوع وندوز يفوم فيجوال ستوديو بإنشاء ما يمى بالحل» وهو عبارة 


بيق پمکن ان يحوي اکٺر من مشروع. داخل. هدا الحل يفوم فيجوال سئوديو بإئساء مشرو ع 


ا 
سل ! 


واحد ما يقود بانشاء نمودچ داخل هذا اا لمش و 


لإشاء مشرو ع ثد بالخطوات الثالبة 2 


mM ۾‎ 


کپ 2 ۳ 4 ۴ i‏ 
|“ قم بفتح برنامج فيجوال سنودپو دوث نٽ. 


| File Ecdlit View Tools Window 
E New Project... Cile 


1َ 


TT] Open Project... Ltrl+Û 


0 £ 


pen File... 


lose 


Ltrl+Shift+S‏ |ھر خاو 


ا 


Recent Projects ۴ 


Exit 


أو 


أ - م/ خالد الجديع : مقدمة عامةعن بيئة الدوت نت › ٥ا۴ P۴‏ » ص۹٠‏ 
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File Edit View Tools 


و 
EEE‏ 


فم باختیار W110 WS App 11٥03101‏ نم اکب اسم 


لمشرو ع 4101ء امم 4ء۴1۲ My‏ ثم انقر علی زر موافق 


lew Project 


Templates: 


Visual Studio Installed tem plates 


A FH 8 


Windows Class Library  Lonsole Application My Movie Collection Screen Saver Starter 
Application Starter Kit kt 


Ny, Templates 


21 YOUSSEF 


Templates... 


A project for creating an application with a Windows user Interface 


| ly FristAppllcatlan | 
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ما لدی عدث ؟ 


بمجرد ضغط على زر موافق قام فيجوال ستوديو 


بائنشاء حل مکون من مشرو ع واحد 


اسمه My ۴1۲٤۲141‏ هذا المشروع یحتوي على نموذج واحد اسمه ۴۵۲۳1.۷0 


إخترت أن تكب بها للثط 


امندادالنماد ج سوف يكون CS‏ وهو اختضار م8121 .٤‏ 


ES MC EE 


| ê. AE 
Î mr FriciApplic ation 
ial Mr Prect 
TI Fommlale 


U So kuko Eopls Dat mate, 


Form Lvl FE Prapailes 

+ HE 

| Boiled Acton Carnpike 
opp ta Dirt Da nt tapF 
Tıanm Taal 

Litany Taal 

Fe amr Farm l hı 


Hir Thi filê ialatai Ea tRiš hulld aril | 


teplopment proces! 
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a Community Hep 
= ° أا‎ 


ET 
EEE Farm sb (Devan) Start Page | 


E |‏ اكا 


1۳ 


3 


9 لاحظ أن امتداد النموذج هو اس وهذا الامتداد يتم إنشاؤه بناء على اللغة»التي 
فلو مؤت باخثيار لغة # اتون لخة كتابة التطبيق خان 


ng Fihrapilicatiûns zena ial Palê AE 


îh 


a Ferm 


Fle Edt Hew Frmyerct Ball Oelg Oi Todi 


دت فى @ 3-4 ت ل 
چ To:‏ 
Mî Wadans Form‏ ` ف 

lk Ponte 

FF Baekgrauna Waals! 
iy Binding gata 1 
| TÎ ndingSares 
lal Bian 
Î Cheeks: 
| FÊ Checbedlıstan 
| Î Cala Dialag 
` FH Commi 
| Î CamtaltnuSmip 
j Paa onde 
| a Dat 
| F DOgrTimePreke 
| a] DirketariErkty 
| Û Oirertam Seach 
E BDamhiUpD teri 
| OD ErorPravakeı 
| |] Enilad 
ûl Fratesitchaa 
| Flel my autPanal 

3 Faller elli ala 
` A FartDialeg 

| FT Gare 

| (FT HalpPreridaı 

FE Holt 


EF mage و‎ 


Eels 
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التعرف على مكونات فيجوال ستوديو دوت نت 


نافذة مستكشف الحلؤل 


توجد في الجهة اليمنى فى بيئة التطوير و تعتبر الاداة الاساسية للعمل مع الحلول و مع المشاريع 
وهي آداة ممائلة لنافڈة المشرو ع ٥W‏ لہ ۴٣٥٥۲‏ التی كانت فی 


ج 


الإصدار السادس غير أنها تحمل إضافات أخرى مثل عرضها للمراجع التي يستخدمها المشروع. 
ويعرض متصفح المشاريع كل عناصر برنامجك من مشاريع ومكونات» وما يندرج تحت كل منها 
من أعضاء وعناصر؛ بحيث يمكنك بنقر أي منها مرتين أن تعرضه في مصمم النماذج لو كان 
من العناصر التي تعرض واجهة _ أو فتحه في محرر الكود لو كان ملفا نصيًا فحسب. 


د 
ie‏ ر ٤‏ عبت ده کژاف 


اختیار الأمر 'خصائص" ۲٠٥1۲185‏ لتعرض نافذة الخصائص؛» لتعدل خصائض هذا العنصر . 
وإذا كان المشروع يحتوي على اكثر من نموذج» وتريد ان تجعل احدها هو اول ما يظهر لك عند 
تشغيل البرنامج» فاضغط الأمر "اجعله كائن بدء التشغيل' زا0 مل۲إه)؟ و 56۲ من القائمة 


الموضعية. 


نافذة مستكشف الحلول 


Salton Explorer wl XxX 
SETPIEE 


3 ly FristApplication 


< aa] My Project 
. Ee] Formlyvb 


YOUSSEF 
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إذا أردت الانتقال إلى أي عنصر في المستكشف يمكنك النقر المزدوج على هذا العنصر. 
على سبيل المثال لو كان لديك أكثر من نموذج في نفس المشروع فإنه يمكنكة الانتقال من 
نموذج إلى آخر بالنقر المزدوج على النموذج الذي ترغب فيه وسوف يظهر أمامك. عند 
اختفاء نافذة مستكشف الحلول وتستطيع إظهارها من خلال 1+41+1)© أو القائمة 
View ® Solution Explorer‏ 


اضافة عنصر أخرة إل المشر و ع فاذا كنت نر بةاضافة نمو ذج أخر ال المش 

عص ا E‏ دري ود اکن کن وون 
الذى أنشأته. قم بما بايا : 

١-انقر‏ بزر الفأرة الأيمن على اسم المشروع - في مستكشف الحلول- لتظهر لك قائمة 
اختر Ad‏ سوف تظهر لك قائمة فرعية lخûر Add New Item‏ 


3 E) Build 


Rebuild 
Publish... 

Mew Tern... | Add 

Existincy erin... Aclcl Reference... 


New Folder Accel Web Eeference.,.. 


Windows Form... Debut 
lser Control... 

Module... j Paste 
CASS... Rename 


I, Properties 
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سوف يظهر لك الشكل اتال و الذي يحوي عدد من انواع العناصر التي يمكن أن 
تضيفها إلى المشروع. فعلى سبيل المثال تستطيع إضافة نظام تطبيقي إلى المشروع و 
[ML‏ إذا احتجت إلى ذلك. ما نريد ا نضيفه إلى مشروعنا هوت نموذج من نوع 
ویندوز وهو ما یوجد باسم ۴017 111٥ W‏ قم بالتظلیل عليه. سوف تلاحظ في الاسفل 
مربع نص لاختيار اسم النموذج الذي تريد إضافته. تستطيع تغييره أو تركه كما هو. 
اضغط على زر 1ع0p‏ 


Addl New Item - My FristApplication > 
| 
Templates: 


Visual Studio installed templates 


= E 2 


Wincdlows Farm Dialacy Explorer Form MDI Parent Farm Aboiıt Box Losin Form 


۳ 2 E ا‎ 
ا 9| ا ک‎ 
oclule Dataset SOL Database Lser Control 


Text File ر‎ 
YOUSSEF 
My Templates 


| Aã blank Windows Fort 


E r 1L ي‎ 
٣ ê E | E E 


| 
| 
ا‎ My F FristApplication 


:-- [ad] My Project 
< ES] FormLvb 
i... Ea] Form2.wb 


YOUSSEF 
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صندوق الادوات فی الفيحوال بيسك دوت نت ' 


صندوق الإدوات 


يوجد في الجهة اليشرى في بيئة التطوير و هو المكار) 


بناء التطبيقات كما يظهر لك 


Rig TE 
k Pointer ر‎ 
2 Background Worker 
7# BindingMavigator 
Ll BindingSource 
Butta E. 
LheckBax 

ê Checkecdll ıstBox 

1 LolorDralog 

E LormboBox 

E ContextMenuStrip 

| ا‎ DatalaridlVlew | 
ق‎ Lataet 


111 


Date lımePicker 
ta] DirectaryEntry 

| Directory Searcher 
| sl DomainllpDown 
 FrrorProvider 

Eventl oq‏ او 

Filedystem Watcher‏ ات 


EH 


Fi FolderBrowserDialog 
ا‎ FontDralag 
|" | GrouıpBox 
HelpProvider 
42 HScrollBar 

aj ImageList 
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الدى پحوی الأدو اث المستخدمة 
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بوجد اا طرةالإضافة أداة إلى تایزج ماااهی كما يلي : 
3 1 
مخبط النمودج. 


ع سل ت ال اليا س ٠اك‏ ا لل | SNN SNA — tll‏ 
1 عن طربق النقر المزدوج ٠‏ ولك بالنفر المزدوج على الاداة انه ناا الثالبه 
وهو ما سيضيفها إلى النمودج. 


۴ ا ۱ 


S8‏ النسخ وذلك ہنسح اداه مو جود مسقا غ النموذج وشل لد لصقها = النموذدج. 


E 
4٠ ا۶ا 1 : ا ء ۹ چ ا ¥ ا ۾ 5ة 1 چ‎ x 2 
شل الإضافاث الجذبدة لی لبدة الدولا للا لبها بإخكصل بلصندون الادواٿث شي انك‎ 


نستطيع إضافة مدخل جديد إلى صندوق الأدوات أو حذف أو تعديل و هي إضافة قوية للتحكم 


بتنظيم الأدوات 0 


ولإضافة شريط جديد 1402~ قم بالتالى : 


-١‏ النقر بزر الفأرة الأيمن على صندوق الأدرات لن" مول لنظهر لك 
لقائمة التی تراها ثم اختثر ظ1 ۸۵4 
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Sort tems Alphabetically 


STITT 


E_Mail: Mohamed.yoyo@gmail.com 


Pointe ¥ List View‏ ۾ 
a Backgt Show All‏ 
7H Binclin EE:‏ 


Feset Toolbox 
E س‎ 
E E 
Fî Fala Delete Tab 
E Comb Rename Tab 
E Lontê Move Uy 
٠ ل‎ Data Mowe Down 


7| DataSeé 


UirectoryEntry 
Directory Searcher 
DomaInllpDown 
ErrorProvicler 
EventlL od 
Filesystem Watcher 


ا 


o" FlowLayoutPanel 


FT| FolderBrowserDnalac) 


E 
=| FontDialog 


Group Box 


۱ Timmer 


Prirvtirg‏ ك 

lw Pointer 

HEH PaceSetuıp Oral orc 
E PrintDialaey 

Pritt oc uırme ryt‏ ا 

PrintPrewiew Contr all‏ ا 


re") PrintPrewleweCiiala cy 


| Cialogs 


kk Pointer 
=| ColorDialog 


Î F olderBrowse| Pointer | 


led] FoantOitalog 


lÊ] OpenFileDialog 
E] SaveFileDialog کے‎ 
اه‎ | E 


There are no usable controls 
in this qroup. Drag an Item 
anto this text to aclcl f€ to the 
toolbars. 


| ف‎ ener al 


There are no usable controls 
ın hrs qroup. Drag an Iterm 
arto this test to aclcdl it to fhe 
tool oz. 


۹۹ 


3 & © 2 
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الصندوق الادوات و يحتوي على العديد من الأدوات اهمها التالى :- ' 


و بخنو E‏ صندو ق الالو ات على الاشرطة التالبة: 


¥ 
ر 
± ہے 


:Crvstal Reports Jiu تقار‎ 


وبها الأدوات اللازمة لإانشاء و تصميم التقارير المختلفة. التسخة اتی تات مع الدوت نت نسخة 


ادا 


شد 8 أ مگانات 


"فو اعد السانات" وأو5' 


2 ت ا : ا ا ج جي يږ کو ر ۲ E ۹ ۴ 1 E‏ اء اھ 1 جج | کا “ ِ » جه 1 
و نحلو ف عل الادو اٿ التي سحاد لاصتال بقو اعد البيانات و شراعة و نحدبب تبالانها. 


وتٽحتوي على الادو اگ التی تستخدم مع تفاذج الإنترنت وهذه الأدوات Web Control‏ تعطے 


كل هذه الادوات السابقة للتعامل مع الويندوز و الإنترنت ' 


أ - م/ خالد الجديع : مقدمة عامةعن بيئة الدوت نت › ٥ا۴‏ ۴ PD‏ » ص۲۷ 
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(فم ( 0ا 
(ساسالح لرک 
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الحزء الثالت من هنا تيدأ اليرمجة 


الفصل الأول :- المتغيرات و الثوابت 


المتغيرات 
المتغيرات تعتبرمن بين اكثر اجزاء البرنامج اهمية. 
والمتغير : هو احد توابع البرنامج الذي يستطيع تخزين قيمة 


هذة القيمة يمكن ان تكون رقم أو حرف أو بيانات أوهيكلية تتكون من انواع اخري عرفنا ان المتغير يتكون من قيمة بقي ان 
نعرف ان البرنامج يستطيع استخدام ومعالجة هذة القيمة و ان يجري عليها العملبات الحسابية اذا كانت رقم والعمليات علي 


البيانات الحرفية كالدمج والبحث والقطع وغيرها اذا كانت حرفية كذلك العمليات علي البيانات الأخري كالملفات الصوتية 
والرسومية من مقارنة وانشاء إلي اخرة . 


هنالك اربعة عوامل تحدد سلوك المتغير بالبرنامج: 


آ نوع البيانات: 
وهي نوع البيانات التي يمتلها انمتغير (integer, character, string)‏ الخ„ 


۲ مجال أو مدي المتغير. 

وهو المجال الذي يمكن للمتغير ان يوجد ويستعمل فية فمثلا لو قمنا بالأعلان عن متغير بداخل دوارة ه۴ فاءن مجال استعمال 
هذا المتغير هو بداخل هذة الدوارة فقط ولا نستطيع استعمالبة بخارجها ولكن لو قمنا بالأعلان عن متغير في منطقة التصريحات 
اي قبل اي حدث أو دالة فاءعن مجال استعمال هذا المتغير هو في كل اجزاء البرنامج ويسمي في هذه الحالة امطهاU‏ اي مرئي 


من قبل الجميع 


۳ امكانية الوصول ومدي امكانية التخزين: 

هي تحديد امكانية الوصول إلي هذا المتغير من اي موديول اخر بالبرنامج فمثلا لو قمنا 

بالتصريح عن متغير بموديول واستعملنا الكلمة المحجوزة ماه»اللأعلأن عن هذا المتغير فاءن هذا المتغير سيستعمل بداخل 
ذلك الموديول فقط ولكن لواستعملنا الكلمة المحجوزة ءiاطںم‏ للأعلأن عن هذا المتغير في قسم التصريحات العامة في اعلي 
الموديول فاءن باقي اجزاء البرنامج من فورم وموديول تستطيع الوصول لهذا المتغير هذا 

بالنسبة لامكانية الوصول أو مجال عمل المتغير اما بالنسبة مدي امكانية التخزين فهذا يعني كم اقصي حد للبيانات يمكن للمتغير 
استيعابها وسنري الفروق بين انواع البيانات وامكانية استيعابها للبيانات لأحقا 


٤‏ عمر المتعير 
وهو تحديد كم من الوقت ستكون قيمة هذا المتغير صالحة للأستعمال. فمثلا لو قمنا بالأعلان عن متغير داخل اجراء فرعي 
بواسطة الكلمة المحجوزةص51 


Dim x As Integer 
فاءن هذا المتغير سوف ينشئ متي الأستدعاء بداء وسيدمر هذا المتغير متي انتهي الأجراء ولكن لو قمنا بالأعلان عن هذا‎ 


المتغير بواسطة الكلمة المحجوزة ٠iاه1ء‏ فان قيمة هذا المتغير لن تدمر عند نهاية الأجراء بل سيظل المتغير محتفظا بها 
الأنواع المختلفة للبيانات: 
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Boolean 
Byte 
Byte 
Lhar 
Short 


WSHorl 


Integer 


Ulnteger 
Long 
WLong 


CLecirmial 


Single 


Couple 


String 


Date 
Object 


SITUCTLIFE 


A bytes 
1 byte 
1 byte 

A bytes 

A bytes 

A bytes 

4 bytes 

4 byies 

{ bytes 

8 bytes 


16 bytes 


4 tytes 


F bytes 


Variable 


F bytes 
4 bytes 


Variable 


True or False 

Oto 255 {unsigned byte} 

“IAF tO 1A (Signed byte) 

Oto 65,535 (unsigned character) 

JA, TOS tO FA, TOF 

Û through 65,535 (unsigned short} 

A, THF, 483,048 to 2,147,483,047 

O through 4,204,067,205 (unsigned Integer) 

HAA TTA UIA, T F5, UR to A23, TTA OTO, DA, 5,0 
Û through 18,446,4407 3,709,551,615 (unsigned lon gj} 


Uto +-FQ,AA2B, 162A TLAOL TIT. O3, A3, 050.335 wth no decimal poIni. 
Oto +702 1025 14261337 O34 3050335 with A28 places 


-JAUOAFEAIFSEFIE to -140T120BE-45 {(negaltrye values) 
1.401230BE-45 to 340282 3SEF3E (positive values) 


-I.FOFONI 14A TOE IOS to OOS TAOMHAE-324 [negative values) 
4.400504112 AA4E-324 to 1.FOFOOI31348O2 1SFOEF 308 {(posfirve values) 


Lependling on the platform, a sirin q can hold approximately Û to 2 
billion Unicode characters 


January 1, OOO1 OOOO to December 31, 4090 1150:59 pm 
Points to any type of data 


Structure Imelmbers have their own ranges 


% 


ملاحظه . 
ان التعرف علي انواع المتغيرات والاختلاف بينها مهم جدا لمعرفة اي نوع بالضبط يمكن ان اتعامل معة فمثلا لو قمنا بمثال 
صغير هو تخزين رقم اكبر من 2,147,483,647 داخل متغير من نوع موه¡ لن يقبل ذلك المتغير القيمة المعطاة لأنها اكبر من 
امكانية استيعابة في هذة الحالة يجب ان يكون نوع المتغير وها أو ماطںهص لأن كمية استيعابها كبيرة. 


انواع الرموز. 


الرموز بالفيجوال دوت نت لها مهام خاصة كما هو الحال بالفيجوال بيسك ٠‏ فالرموز تستخدم للأعلأن عن انواع البيانات 
المختلفة وهذا جدول مبين بانواع البيانات مع الرموز التي تالأكود البرمجي إليها وهي من النوع الالأكود البرمجيي الغير 


2 


e | 


فمثلا لو اردت ان تعلن عن متغيران احدهما نوعة 
ودا والأخر نو عة وہ S٣‏ 
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Dim x&=5 
Dim y$=""salem7it - Youssef" 


وكما نعرف فاننا ملزمون بالأعلان عن كل المتغيرات في برامجنا ١١‏ كان الخيار 
Option Expاicit On‏ مفعل اما اذا کان غیر مفعل فنستطیع ان نکتب اسما المتغیرات واعطائها اي قیم 
من دون تحديد نوع البيانات متلا 
الآأكود البرمجي 
Dim x=10000000000‏ 
Dim y =" "salem4it - Youssef"‏ 


وتستطیع تعدیل الخیار †iiام Option Ex‏ من القائمة وا٥٥۲‏ وتختار sہOpİio‏ 

ومن شجرة العرض نضغط علي وہہناںuاہS‏ ۵ھ ءاcمزہ٥‏ وثم نختار وtاںه]م5‏ ۷8 أو نستطيع ان نعدل هذا الخيار بكتابة 
العبارة "0 ا‌iام×٤‏ هنام للتفعيل في منطقة التصریحات العامة أو 0۴ †ا‌اام×٤‏ ۸٥نام‏ لألغاء التفعیل ویجب ان تعرف 
ان الأعلان عن المتغيرات مع تحديد انواع البيانات التي سوف يتم تخزينها بالمتغيرات مهم جدا وذلك للتعامل مع الذاكرة بشكل 
افضل وسبب ذلك اعلام الذاكرة بالمساحة الفعلية التي تريدها متغيراتك لتخزين البيانات كي لأ يحدث خمول 

للذاكرة بسبب حجز مساحة كبيرة منها لمتغيرات غير معروفة النوع ورغم كل هذا فاءن الفيجوال بيسك دوت نت حل مثل هذة 
المشكلة باعطاء نوع من البيانات للمتغير بحسب القيمة المسندة إلية فمثلا 


الآأكود البرمجي 
Dim x=10000000000‏ 
Dim y =" "salem7it - Youssef"‏ 


المتغير × من النوع وہ ه! والمتغير ر من النوع وہا١Š‏ 
وهنالك ايضاء بالفيجوال بيسك دوت نت انواع من الرموز تسمي بالرموزالحرفيه وهي تقوم مقام الآنواع التي تدل عليها وولكن 
طريقة التعامل معها ليس هي نفسها التي استخدمناها سابقا مع الرموز الغير ابجدية وهذا جدول موضح لذلك 


ت 
ج 


| 


Sor 
Ulnteger 
لا‎ 


Ghar (note that this is a lower case “¢")} 


والأن ناتي لكيفية الاستخدام افرض انك قمت بكتابة التالي 
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الأكود البرمجحي 
X=100L‏ 
Y= "A'"c‏ 


وهذا القيمة الأولي وه! والقيمة الثانية من النوع ه٥‏ ولكن يجب ان نعلم اننا لأ نستطيع ان نكتب المتغيرات بالشكل السابق 
الأ اذا کان الخیار 0۴ اا‌اام×ع «٠نام0‏ غير مفعل كذلك يسمح لك الفيجوال بتعيين انواع القيم باستخدام رموز حرفية 
مثل 8&1 للبقيم السادس عشريه 0 للقيم الثمانية 
الأكود البرمحي 
i = 100 ' Decimal 100.‏ 


i = &H64 ' Hexadecimal &H64 = 6 * 16 + 4 = 96 + 4 = 100. 
i = &0144 Octal &O0144 = 1 * 8 * 8 + 4 * 8 + 4 =100. 


ايضا يوفر لنا الفيجوال الكثير من دوال واسإليب التغيير بين انواع البيانات 
أستخدام الوسيلة_( )ماص هله لتغير تنفيذ البيانات الناتجة من الأمر ( Rnd(‏ ` 


Randomize) 


و هذا الأمر يجب تنفيذه مرة واحدة قبل أول تنفيذ ل0)ك١۸.‏ 

في السطر الخامس يتولد رقم صحيح يأخذ قيمة من (1) إلى (5) هذا الرقم يتم 
تخزینه في المتغير "۲١١ء٥5"‏ ولتوضيح هذا الأمر أكثر نفترض أن ۸”40 آأرجعت 
القيمة ”0.46705“ وعلي هذا فإن قيمة (40صR×‏ 1+5 ) تكون ”3.33525“ و سيتم 
تخز ين القيمة(3) في المتغير "أعإcءمS"‏ لانه من النو ع "عِعع†م]" . 


| 1 1 


السطر_ السادئس لو صح اذ اله InputBox()‏ و ألذ اله عدار د عن برنامج صنعنز_ باخ 
قیم كمدخلات تسمى المعاملات ( sأرعصسسعھ)‏ ویخر ج نتيجة تyaı (Return Value)‏ 
. كمثال لذلك هناك دالة لحساب الجذر التربيعى متاحة فى ( Visua1 Basic. Net‏ ) لو 
أخذت هذه الدالة القيمة (9) كمعامل فإن القيمة (3( هى القيمة النlائتجة (Return Value)‏ 
لهذه الدالة فے , هذا المثال. 
چ قي آ 
1 ا“ :ات ا للل 7 فیا ےھ الاھ کے س لق 3“ 1[ 
نفسلل الضيء بإنطبي علي الذاله InputBox()‏ فهذد الذالك تحر ص نادد نحنو ی علي 
إشارة إدخال ومربع كتابة لمستخدم البرنامج لكى يدخل ما يريد؛ وكتابة المستخدم لإشارة 
الإدخال هي معامل الدالة (sأ«عسسعءف)؛‏ والمعلومات التي يدخلها المستخدم في مربع 
الكتابة تعتبر ايضا اJ‌) Rem Value‏ )؛ علما بان )Return Value)‏ تکون من النو ع 


Ê 


Return) حتي لو ادخل المستخدم ارقاما و علي المبرمج ان يقوم بتخزين‎ "tr" 


gÎ( Value‏ طباعتها. 
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الفصل الثانى من المتغيرات و الثوابت 


أولاً : المتغيرات 


قبل البدء في الدرس أحب أن أنوه أن إلي أنه هناك بعض النقاط المفتوحة في الدروس السابقة والتي سنعود إليها بمزيد من 
التفاصيل في حينه 


ومن أجمل ما قرأت فيما يتعلق بالمتغيرات هذا الدرس ' 


رالان سدور حابي درل مساریه ومدنریات إطار غل )ه۴۲2 ۸8 , یی ان لسم لك مریه 
إلى اقثر من 10 طبقات» ولكئي فضت تقلبص العدد- للتسهيل علبك كما رى في اعد الشكلبن التالببن. 


تيف اللفة المشتركة ‏ با 


1 1 (لمغة الوسيطسة] __ | 


ىلاج | صفحات 5.16 | خددات رآ | 


windowsê |‏ 
نطبيفات أ۴ر .م5 


لمات + اران windows‏ 
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مکئبة شات طا as5اC Base‏ (نسمی بضغا مئت فت NET Framework Class Libary‏ . ( 
هي عبارة عن منات الات الموجردة ٺي عشرات ملغات ان ]0 تعر ثرا غالا سيل له تعاب الب مخين الخادين: 
حيث نتوي كل ما تحتاجه لإلنجاز برامجك ومشاريعك بدءا بنقديم لفات لوصف البيانات الأساسية ( ك عن ماما 
trin:‏ ) انی ادارة خرج ودخل المنفات ومأ55ععو۴ ٥ا۴‏ 0//| , مسارات التَنْفبدٌ وم أكdة ٣٣‏ , الضصور 
واترسوب نمك Web Forms ii , Windows Forms‏ , الإاتصال بقواعد البيانات آ٤ل[. A00‏ وغيرها 
الكثير. 

بالنسبة للغة التنفبذ المشتركة )©L( - Common Language Runt‏ لھی موا لنعابیر جسم لداب 
آ۴ , الاخرىء كما آنها المسنولة عن عمليات إدارة انذاكرة me٣٤‏ ِو Nemory Nana‏ , تفريغ مصادر التظام 
باستذام Garbage Cهااععاآ o‏ اخطاء رنت التiفi Exception Handling‏ . 

اخبراء لظام النشتيل الذي يمكنك من ثبت اطار عمل wor‏ م ھ۴ E۲‏ یه خو ست لہا۷۷ فقط ؛ راکن فد 
ترى في القريب العاجل نظم تشغبل اخرى داعمة له 


الشروط والقيود على تسمية المتغيرات' 


رشا عند تعر ش ۱ 


٠‏ ألا يكون قلمة من كلمات اللغة الأساسية تلك التي نر اها باللون الأزرق).. مل اں؟ و ۲و۴ و ۴| وغرها.. ان الجطة 
الثالبة غير مشب ل٠ Dim Sub As Integer‏ 


ولكن لو كنت مصرا على مثل هذا الأمر» فبمئنك ان نضه الاسم بين وسين مضلصن [ ]. هذه الجملة مقرل" 
n [uk] Ma FLejsf‏ 


لن عليك في تل موضع تنام فيا المتغر ان تحيطه بالقوسبن المضلين : 3 sub]‏ 
٠‏ الا يزيد عن 255 خرفاء وهو رفه كبير بالفعل بها بثلي. 
٠‏ أن بترن من تة واحدة ا تتخللها المسالات.. ويمئن استخام الشرطة المنخنضة "_" للفصل بين مقاط الكل 
بذلا ن المسافات. 
با يبدا ٻارقاب وان کان من الممڪن ان تتوسطه آرقام أو پنتهي بها. 
٠‏ الأيطوي على أي من علامات اللتصيص أو الأنواس أو النقطة "": ولا علادات السليات الحصسابية أو عسات 
المقار نة الحسايبة او المنطفيك فل هه العلامات محجوزة لو ظانف أخرى. 
٠‏ غير مسموح بثكرار اسم المثغير داخل نفس النطاق؛ فلا يمان تعر يف نرين مالين في الاسم داخل نفس الإجراء» 
وان كان من الممكن تكرار نس اسم المتغبر. لن في إجراءات مخف 
والمتغبرات لي لفة البيزبك تنجاهل حاله الاحدرف فبا أوروومأ-ووو: تالاسماء و وؤ ر وور د ۲A G٤‏ لبا 
مكالنة: ونشير للش المنغير.. معي هذا ألك لا تسنطيع اسنام هذه الكلمات لتعريف ثلاثة متغيرات مخئلفة: فكلها اسما واهدا. 
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انواع المتغيرات' 


القيمة التي يمكن تخزينها 


-32 708 - را32‎ 2 Short OR Int16 
0 - 65535 1 UShort OR Ulnt16 


û - 429400725 


SFFEETPFNEL LU PTET IC FFEETPIVETELET FCT) Long OR Int64 


O - 18446 744073 7091615 ULong OR UlntbB4 


AO2E2e+O3ST - 3.40282 +U38T 4 Single 0 |‏ .3« | 
e+308 - 1.79709 +308 4 Doubla [:‏ 7970 .1- 
-FAL2EIbL514204335993543950335M - 8 Deeimal :‏ 
22l25 14208433759354395033 )‏ 
String ۴‏ 2 دد الحروقا اي ملسلة نصيه من حروفا وارقام وروز و ... 
char 9:‏ 2 آي حرف آو رقم آورمز و ... 
U.‏ ۴ 1 
Boolean E‏ 1 التمة عر م] او عfals‏ 
| £ | 
ع ع DateTime‏ 8 تاريخ او وقت بكل التلسيقات المخئثفة . 
e E‏ 
Object r‏ 8 أي ية من القيم السابثة . 
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أنواع المتغيرات والعمليات عليها ' 


المنغيرات الرقمية عاط Numer ۷2a‏ 
لن للمتغرات الرفية أنراغا عدبدة. تبقا لحجم الد ردقه الشرية.. وعبك أت ان نخد النوع | لدي بناسبك؛ اضعا في الاعبار 
ن الأغداد ذات اة الشرية الأكبر. تكون الصلبات لبها أبطا من الأغداد الصمبدة والأغداد ذات الد العشرية الال 


OSE 
الغمليات على الأرقام‎ 
لن تكون هناك فاندة اذا كنت ستضم الأرفام في منرت دون أن نسنطيع أن جر لبها بعص العلبات الحسابة.. وف‎ 
الجول التالي علامات العلبات الحسابية الأساسبة‎ 


+ إت 
ا < i‏ 
EET‏ 
علامة القسمة.. ويمكن أن يكون الناتج عددا صحبحا أو به أرفام عشرية.. فمثلا: 7/2 =× 
ستعطي النائج 3.5. 
عاشة القسفة أيضاء ولكنٌ الناتج هو العد الصحيح فقط. . فتلا : اچ 
ستعطي النائج 3 
ويمئن أداء نفص العلية باستخدام الدالة م1 لو شنت الا ترتبك بين علامتي القسمة 
وذلك گالتالى: )7/2( X= Int‏ 
إحدى عاامات القسمة أيضا: ولكنها تعطى البافى من القسمة فحسب.. فمثلا: 2 ل0 7 = X‏ 
سيعطىي الناتج 1 الذي هو غبارة عن باقي القنمة. 


لأس.. فمثلا 2 × 2 × 2 تكتب رياضيًا بالصيفة 2 ونكتب في البرمجة كالتالي: 2^3 
ولو أردت أن تعر عن الجذر التكعيبي مثلا, فارفع العد للأس (1 + 3) كالتالي: (1/3) ^2 


- أ.م/ محمد الحاج : محاضرات مادة ۷8.6٤‏ (نظري + عملي) › ٥ا۴ P0۴‏ > ص٣١‏ 
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ويجب أن ألفت انتياهك إلى أهمية وضع الأقواس في العمليات المتداخلة. وذلك حثى تضمن صحة إجراء العفلية بالترتيب الذي 
تريدها به.. إن الترتيب الطبيعي الذي يجرى به ۷8 العمليات الحسابية يسير تبعا للقواعد التالية: 
- ينم تنفيذ ها بين الأقو اس أولا. 


- إذا لم تكن هناك اقواس يتم ثنفيذ الأسس اولا. ی 
- ثم يتم نفيد الضرب والقسعه. YOUSSEF‏ 
- ثم باد دلك يتم تنفيد الجمع والطرح. 
لهذا فان الصيغهة: )87)13 
تعطي الناتج 2ء وذلك لأنٌ القوس ينقذ أولاء فتصبح العملية هي الجذر التكعيبي للعدد 8.. ولكن لو أزلت الأقواس كالتالي: 
81/3 
فان الناتج سيكون 2.666666 وذلك لان الاس ينفذ اولاء فتصبح العمليّة كالتالي: 3/3 
بقي شيءَ هام.. ماذا لو اردت أن نزيد قيمة متغبّر بمقدار 1 مثلا ؟ 
في هذه الحاله سنقوم بالتالي: 5 X=‏ 
Y=X+1‏ 


صارت قيمة المنغير 6ا ×X=¥۷‏ 
حيث اعتمدنا على متغيّر وسيط جعلنا قيمته هي ناتج جمع المتغيّر الأصلي فع الواحد؛ ثم نقلنا قيمته إلى المتغير الأصلي. 
ولكن مثل هذه العلية تتكرر مرارا في البرمجةء حيث تحتاج مرارا لزيادة قيم المتغيرات او إنقاصهاء أو ضربها في رقم... إلخ. 
فلو كان على المبرمج ان يكتب هده الخطوات في كل مرةء لصارت البرمجة جحيما ا يطاق! 


وبالتالى يمكنك أداء هذه السلية في سطر واعد مباشرة كالتالى: X= X+ j‏ 
لأرل وهلة سنبدو لك الصبغة غريبة؛ ولكن حاول أن تفرأها كالتالي: قيمة × الجديدة تساوي قبمئه الفديفة + 1. 
ولا يشترط أن أجمع على المتغير الرفم 1 فحسب؛ فهذه العملبّات أيضا مباحة: X=X+13‏ 
X=X+X‏ 
5= 
X=X+Y‏ 
ولا يقتصر الأمر على الجمع فحسب بل يمن إلى باقي الصلبات الحساببة: 
القاص المتفبر بمقدار 4 ' A=A+24‏ 
ص ضرب المتقر فى 2 ' a*2‏ 
YOUSEF‏ فسمة المتفير على 9 ' N=X/9‏ 
رفع المتغير لأس 3' X=X^3‏ 
کان هذا هو ما اعتاده مبرمجو 86/.. ولكن هناك تسهيلا إضافيا تقذمه لك ا۷8.16٠‏ عن طريق استخام الرموز =+ ر = 
و * و إو ^ و... والجدول الثالي يريك فة استخدامها: 
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نطاق الأعداد : 
والان : استخدح الكود الثاني لاختار اني 2 المتقزات.. ستجذ اننا تسنخكد خاصة "اضفر قم" عںآھ ۷ہ آایا: و "اکير شب" 
MAX Aue‏ عرض نطاق نوع منها. 


Ae sa qelax Sam {(TUylLE " e yl. Minvale Ff " a f yS Martal #5] 
Acasaglclcgz. Show {("SEyFltc " & SUytc.On¥alıc & " Tz "#4 shyt .Hax¥a_uc) 
ETS She Seh " & Seorl _ MnVaie # " " Shor. Marwa ut 
HraSagzlEor. Show "DyTS " & Dyrtc. Mnvalire & " Ee + yt. orm luc] 

ta SıTZEOX .Shokw {"IMtlb " & Inlet .SGOaluc kk " Fr " E _nTlIb. BET a AMC) 

hr CHE mow {(lnleqer " Rf Inleger Minas Êê " o " fF Meger YazYal ıe] 
CS SaAqSEGZz oho" intl " & Int Minvaluc ا و‎ " E NLL MARY a2a-_UC 
Ms22a3sEoz. Shor {"Lsng " š LongiMin¥alus 4û " k2 °" $ LSr3 .HeaXVal as] 
Acasagzlcza. Show {("inttEd " & IMTCb4.Min¥aluıc & "Sz " & _RZCYIMARTA-UC) 

AeA HF! aw ("Sims " û Simla Mn Valina * "r: " F e 
dea rge ER iw ("Urabe " & ele inala f Tr; " fF leb eMaxvalul 
Hcssaıq2Eox.Show {(SLccimal " & Uccimgl.invallIz & " Io "E De e. 213 Valu إ‎ 


ما لا نهاية والقيم الشاذة |لiخZرJ ‘Infinity And Other Oddities‏ 
يستضدم ۷8 في الحصابات الرقمية القيمتين "ليس رفغا" ل3ل (التی فی اختصار لûiبير Not a Numbêr‏ „ "ما 
نھایة" بام آآماء وذلك لإعلامك بان شیا لیس على ما برام قد تد في حسابائك لثنخذ التصرف المناسب بدلا من ان 
بعرض لك 8 رسالة خطا كما كان بحدث قي الماضتي. 
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ھا لا Infinity aıldi‏ 
ان بعض العسليات الحسابية ء كالقسمة على صفر . تعطي مالا نهاية.. ولو استدعيت الدالة "حول إلى نص" وا٣5٥٣‏ 
على هذه القيمة؛ لكان الناتج هو النص "ر٤آ٣آ۴"]”..‏ فلثرٍ هذا المثال: 


Dim X As Double = 499 
HagEox( & 7 Û 7 

سيظهر لك النص "رخأما؟م!" في الرسالة. 
سبب آأخر للمالا نهاية هو قسمة عذد كبير جدا على عدد صغير جداجداء لدرجة تجعل الناتج يتجاوز حدود المتغير 


المزدوج.. جرب هدا المثال: 


Dim LargsVar =;l0 ^*^ 989, SmallVal = 10 * 999 
MsgBox (LargeVãr / Smallvar) 


أيضا سيظهر لك النص "رام آ۴م" في الرسالة., 

وإذا ما عكست هذه العمليةء بقسمة العدد الصغير جدا على العدد الكبير جداء فسيكون الناتج صفرا.. الواقع ان الناتج سيكون 
عددا صقيرا صفيرا جدا جداء ولكن المتغير المزدوج لا يستطيع التعامل مع ستل هذه الأعداد القريية حدا هن الصفر 

لیس رفما ۸ YOLESEF :N2‏ 
هده القيمه توضح ان ناتج عمليه ما ليس معرقا: ليس رفماء ولا صفراء ولا خض مالا نهايه. 

فمثلاء ستنتج لك هذه القيمةء لو حاونت أن تحسب اللوغاريتم لعدد سالب أو لو حاولت أن تقسم صفرا على ضفر (0/0): 
فهما عملبتان غير معرأفتان رياضياء وليس لهما معني.. جرب هذا المثال: 


Dim Yarl A3 licuple = f, Var Az Doible = f 
MsgBox (Vat / ¥ar2) 


ستظهر لك رسالة ترف النص! "4۸" لاحظ أك لو جعت فيه ۷4۲2 صفبرة جدا مل 18-299. فان الناع 
سفرا, ولو جالت قبمة ۷/۲1 صفيرة جذا؛ فسيكرن الذالج ما لا نهابه, : 
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العمليات و الأختبارات على الأرقام' 


اخنبار وحود "ما لا نهاية" و" لیس رleê" ‘Testing For Infinity And NaN‏ 
الأسر بسبط: التحفق من هانين الفيمتين؛ استخلم الدالتين: "إنه لبس رقما" 84| و"إنيا مالا لهاب" 
۷اا nاواء‏ اللثين تجدهما من أغضاء المتغيرات المفردة والمزدوجة , ولمعرفة إشارة الما لأنهاية. اسئخام 
الدالتین: "انها ما لا نهاية سالب" اا Ne gav۴!‏ 5| و" انها ما ¥ li‏ مرجب" .\sPositivelnfinity‏ 


واليك مثال تو ضيخي. 


Dim Varli = Û, Var = (, Result As Louble = Varl # Var 


If Double: Talnfirnilty (Result) „Than 
Tf Daubla;ISPosi1tiveInfîinity{Raault)} Thaf 


: ۳ ا 2 1 1 ۱ LI‏ 
[إفقع لفط حلذا.. ل كن الاأسشتنعرار | NagGBdx‏ 


1 


فا ل تهاية ساا نت ' عدا 
زقتح صضقك حداء.. لا عكر الاسنمر از 0 MaGBOx‏ 
End If‏ 
Elgell Double, laKMaN [Result) ThERL‏ 


["حطا ليس برقم ") ٭g80د1‏ 
جاك أي عطاً' ع14 

ع " اللتيجة هي ")£× 12380 
End TE‏ 


هذا الكود سيعرض الرسالة "ليس برقم" ۸۸.. ولكن لو غَيّرت قيمة ۷4۲1 إلى 1> فستنتج ما لا نهاية موجبة 
ولو غيرتها إلى 1١‏ فسننتج ما لا نهاية سالبة, 


13ê 
Failurs =False 


- 
- mi 
mm 


واضع جذا ان الصيغة الأولى نختصر خسة اسطر في سطر واحد ففط! 


- أ.م/ محمد الحاج : محاضرات مادة ۷8.6 (نظري + عملي) › 6ا۴ P0۴‏ ۰ ص۱۹ 
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mad 
طط لاا‎ 
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string Variables aةضنلا المتغيرات‎ 

يٿ نعريقها کالتائي: Din SsnsText #s String‏ 
الآن يصبح بامكانك أن تضع آي نص؛ مها كانت مكوناتة [حروف» رموزء أرقاد: علامات تنسيق... الخ)» ومهما كان طوله 
(يمکن آن صل إلى 2 جیجا بايت: أي 2 مليار حرف!). 

وهذه الجمل ثريك كيقا تستخدم المتغير التصي: Dima AStrinq As Skrir‏ 


ا -- 
 » 1 - 3 8 2 r" 17‏ 1 ا Ti 1k‏ 
E E"‏ لے سا لس E e n‏ ت ال 1 سا سوط d‏ 
د 1 TT‏ ج 
FP 1 1‏ ات ر 8 = ٍ ۲ 0 
,ا کے ے 3 :1 1 = = = 1 1 : - hg EEE oT‏ 3 
لطر ت تتلالنت ا ا تا يال إا ا3ال الف | | جحلو J‏ ع ت 1 2 11 ےا لط 
i [ xa" TI‏ 


طبعا لاحظت ان النص يوضم بين علامتي تتنصيص.. وها بالتاكيد سيدفعك للتساول: مادا لو اردت ان اضع علامة انتلصيصس 
قى هذه الحالة يجب أن تكتب آربخ علامات تنصيص كالتالي: Stine = mr‏ 
وهلاله حل أخر: هو استتخذام الذالة ج للتعبير. غين علامة التتصيص كالتالي رول عط ددع > 


Ui iS LLIN mS 
سو ال أخر سير اوندك: ما القارق بين التعحدر بن التاليين:‎ 


im Aurea Re TNF = EON 
ULM MSLCLITG hating ala RDN 


إن كلا المتفيربن يحمل قبمة مختلفة عن الأخر: 
فالمثغير النصيْ ومأ)۸5 يحوي على سئه حروف» وهي "2" و "5" و "" و "0" و "0" و ٠"0"‏ 
بيما الد الصحيح ۸۸158۲ بحتوي على رفم واحد هو 25000. 
2- بما أن کل حرف بتم نخزينه في وحدئي ذاكرة ول8 2» فان المنقيّر النصي بخزن حروفه السنّة في 12 
وة ذاكرة بينما بخزن الد الصحبح الدد 25000 في 2 ( وحدنان ففط) , 
ولكن برغم هذه الفلافات, فن بإمكالك أن تستخدم المنفير النصى ومأ۸5۲ في العمليات الحسابيةء ونستظم المنار 
ال رمي 8۲ ط۸۸ في العملبّات لصب حبث بوم ۷⁄8 بالعلبان اللازمة للنحويل بين النوعبن (ما لم تمنعه من القباد 
بذك باسنخام جەلۂ „(Option Strict On‏ 
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دمح النضصوضص nہټConcatenai:‏ 
ماذا لو أردت أن تلم نصدن؛ بحيث ينج نص جديد بجمع الاين معا" 
بسيطة,. اسلظم علامة الجمع "+" كما اغندت في استخدامها بين المتغيرات الرفمية: 


0 EE 1 11 
| A A35 OILPTIN = EE 
1 1 . ت‎ FI 
u 7 JNIYTCIS IE 


A 3 ا‎ 1 1 آ١‎ OT ا و اه‎ : n 
وحلى ل تشر اللصوص بالعيرة من الاقام فان بامكالك امتخام الصيف المختضرة ليه:‎ 


 I- " Trezêntatilûn " ۴ „ 4= " Tregentation 7 

ولو نٽ لقشس من الا اك في قرا الود سل الج الحسابي و شبك اللصوص. فاستخدم العامة ك دد ق الداأمة E‏ 
للل" Lim A hs SLIÎng‏ 
A #& & "JnIYCISITY "‏ 


ud E. TuLVCrSITY " 


المتغیرات |ل=رıèة Character Yariables‏ 
هي متغيرات تخجز وحدنا ذاكرة 85ر6 2؛ يمكن أن تخزن فيها حرفا واحا.. ولظرا لأن الكمبيوتر لا يعرف شينا غير 
لأرفام» وآي شيء يحفظ به يجب أن يئم لمثيله برقام تلل عليه فان اللمبيونر يملل الحروف بارفام من النوع "عد فصير بدون 

شار" (n116|لا)‏ ntegersا Short‏ gnedاnsل..‏ فمثلا الحرف "و" بمئله الرقد 65. 
لهذا فان بإمكانك نحويل الاعاد الصحيحة إلى حروف: باسنفدام الذالة [)2۲؛ وتحويل الحروف إلى ارقام: باستخذام الدالة 
[إأعsه..‏ جرب مأ بلي: 

MiqEu# (Auc {(" |)‏ 
ستجد أن نافة المخرجان تعرض الرفم 65. 
إ ئك استظاد جملة قالنالنة لنعريف منضرات حرفة: Dim Charl, ChHATZ Aa Char‏ 
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ربامگالك أن تضع قيمة ابئدانيه في لمر الحر فى علد تعريفه. سراء أفالت حرفا اد نضا في فى الحالة الأخيرة سبنم وضع اول 
حرف ففط في المتقر).. رب ت پٺي: Tin Chari Au, Char = "a", hecê Au Chal = "ABC"‏ 
Mrs saq2Eozx .Ahoa (Charl)‏ 
Mesa qBRHE , Ahera ha r)‏ 
نظ أن شاشة الىخرجات سنعرص ما بلى: 
1 
4 
ولكن الطريفة السابفة لن تعمل إا كان اخنيار "النحويل افق" فعا © إء ا٣5‏ مواام 0 نهدا بجب اسنظام الطريفه الإنيه 


للنعد . عن الخروف- Dim Charl FAS har E‏ 
خيث بخبر الحرف ¢؛ ۷8 ان ما بين علامتي التنصيص حرف وليس نصا.. وى هه الحالة يجب ان بكزن ما بين علامني 


التلصيص حرف واحدذ بالضبط: حبث ن بقبل ۷8 جملة كالتالبة: Diu Charl Al Clar = “abit‏ 


ل ازل حرفا ع پجرار ملي التنصبص هر ريه 8 لي پرمز دروف زيهشن اسنځامپا ې اف موضع كالتالي: 
LimnêLharl As chr ar"c‏ 
iharl = "hir e ERI mul‏ 


والمنقير الحرفي يلك بعض الوسائل الشيقة: مل "إنه حرف" ١ع)اعاوا|‏ و"انة رذ" ا و"إنه علامة رفي" 
sPunetuationا."“...‏ الخ , لو جربت الجمله النالية: McssaqcBoax. Show (Chaz. IaDiqit ("J j‏ 


لظهر لك في نافذة المخرجات كلمة "۵لا1۲" , جرب أبضا ما ۴ 


Mcssaq2Eozx. Bho [Lhar. lsFuncEuation 


Lim A fia Char n 
Meu HAGgSBux . Show (Chass TuDigIL a) | 


im û Az MAT = 

MzasaqcEozk , Shon (Chaz. ISDIqit (2l 

ستحضل على نفس النتيجة.. طبعا بمكك أن تلاحظ أن الداله ٣ان‏ |80| مي داله مشنركة 514۲84 بمئن استظ اميا من امثير 
الدرفي» أو من هل النرع الأساسبة a38‏ 14۲].. بل حلي يكن استظامها من أب دال ناتجها درف.. جرب المثل النالي: 
Wim # Ar SlLring = "MAI"‏ 

ca saqcbox sho hoz ade DI1T A, 
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ستدصل لى تفس اللتبجه وهي ع٣1‏ ولا ناج لض الإبضاح لالداله "عررف" إو اظ رف الدرف الذي تربد 
معرفته في التص: ولرجع لك ها العرف.. ها مغ فلاعظة ان العرف الإول لى الل يوجد في الموضل رفم ل.. إلى ها بسن 
ارف حيث يمن اسنطاد جملة ئالذالية: MaaaqeRoz ahr (XCar‏ 
بث سبظپر ك في نافة المذ رجات ما لي 

حبذ إن "2" هو الدرف الموجود في الموفع 1 (العرف الثالي) في 

لگن با آن الال ()4۲5٣اع‏ ترجع حرلا إن لبن نطبيق ودل 2 #لبها؛ گالئالي: 


Console. WTICSLINSWDAL. ISLIGIMA.LAATS 1)} | 

وتلاعظ آنا نم ترسل حرفا لال "انه رفم" أو 50| كما فعا من فل ول رسلا لها المتقير اللصني )ل وموضع الدرف فيه 

الاي نريد اختبار و ردا ام لا.. ولا باس في هذاء فالدالة ٣ال‏ |50| لها تعريفال يخلفان فط لى لوعبة الساملات الني تفبلها 

الال أطهما يمكن أن ترسل فيه معاملا راخدا للذالة؛ هر الحرف ادي رذ اختباره رالاخر تسل ليه معاملين لدا أحد 
اللصوص وموطع انحرف انراد اختباره فيه. 


تعريف المتغيرات' 


المنغبرات الرمنيه 5ع اداة ۷a‏ عا0a:‏ 
بد نخر ین متغبرات الثاربخ رالوفت بتلمبف خاضص ماداد مز دو جة. بحبث بم العد الضحيح الذاريخ: ويمثل الجر ء العشرء الزن 
وينم تعربف هذا اللوع من المتفيرات والكتابة فيه بطرف كالتالية: Dim MyPata a Tata‏ 


MyUalt = FIlfUlFZLUO# 


MyDatc [11/012006 6:28:11 PMI 
a "Nov l1, 20b" 
1 [ar How تعطيك لناإلشحخ و الوفت ا “اللي‎ u3 دالا‎ 


تلاحظ اننا لكتب التاريخ بطربفتين: : افا گتار یڅ رشي مگٽوب بين علامتی چچ او تاريخ نصي موب بين علامتي تنضصيص "". 
حيك سيتم تحويله ضفنيا في الحالة الأخيرة؛ إلى تنسبق التاريخ والوفت المنامب. 

تما أن بامكاك اسنظام الدوال الجاهزة التي بمنحها لك ۷8 لنتعامل مع التاريخ والوفت.. فمثلا: يمكنك استخدام الدالة "فرق 
التاربخ" ()۴۴ا02180؛ لحساب الفرق بين تاريخين مختلفين؛ وبالوطة الزْمنيْة التي تختارها [إسنوات , أشهر , أسبوع, أيام ؛ 
ساعات» دقائق , ثواني ...).. اليك هذا المثال: لحساب عدد الأيام انئي عشناها في هذه الألفيه: 


im Leys As Long 
Day LDatcUllf lM Datcthtcerval. Dayê ISL EULl, Nami!) 


- أ.م/ محمد الحاج : محاضرات مادة ۷8.6 (نظري + عملي) › اا۴ P0۴‏ > ص۲۰ ص٣٠۲‏ 
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المتغیرات الكا نات اع [(0: 
شذا انوع سطع نين آي وم من الائات سواع من الانوا ع م السابفك أو من آي گان أخر نعرفا اللع أو تعرفه آئت. إن في 
هذا النوع العا بمئن أن نضة فيه أي رع من الببانات دولما قلق! للأسف: # تبدو آلآمور بيده البساطة؛ ففعل ذلك سيكون له انار 
جانييه سيْنه. ففبل ان يستخدم ۷/8 هدا السفير الان ل بد له ان بعرف نوع البيالات الي به اولاء ليبوم بسليات التحريل 
المناسبةء للتعامل مع هذا النرع من البيانات.. فمثلا: لو كان المثغير الكائن بحنوي على غدل صحيح؛ فلى ۷8 أن بخوله إلى 
نص قبل لصقه ينص آخر.. مثل هذه التحريلات نمثل عبنا على سرعة البرنامج.. لذا فعليك اسنذدام المتفير الكائن عدا في 

الات الضرو رة فكب 

Lim Vaz is و‎ 
Tar : Haq E “ . GEtETYpc.TLiString | 
Yar 2? Sel : UsgBoz lv Ar. TypE., Tostr1ingy 
Yar “A cC ; MSFEOK{ YAT GST TYp2.ToSTtrIng| 
Ar = Hol} f MEJlOZ (VET. TET ype L'ortTtrIng) 
ar =, "raha" 2 Mad ear tet Type. Toft] 


المنغرات الرمنيه :02٥ ۷2 ٣اةادا e5‏ 
يتم نخزين متغبران اللاريخ والرفت بتلسبق خاص باعاد - بحبث بم الد الصحيج الاريخ؛ ريل الجزء العضري الزمن 
ولم نوربف ها الوع من المنفيرات بالقناب فيه بطرف نال Lim Myrate û Tata‏ 
Myla = FIlFULFELURF‏ 

MyDatce ALU/UIFAUU bd: l1 PMI 

2 E 1 I" 


ذالم اإن" تعطيك لتاشم وال قد IC ow) ul‏ 


لاحظ الا لكب الناري نطریشن : إا ناريخ رسي ۽ ملوب بن لامي چ اب ۽ اريخ لصي ملتوب بين اقلامتی تنصيس "". 
حب سيم تحريله ضنبا في الحاله الأخبرة؛ إلى تلسبق الثاري والوفت المذاسب. 

كما أن بامكاك اسنام الدوال الجاهزة الئي بمنحها لك ۷8 للنعامل مع الناريخ والوفت.. فسثلا: بمكلك استخدام الدالة "فرق 
الناريخ" [)١۴ا04180؛‏ لحساب الفرفى بين تاريخين مختلفين وبالوطة الرمبْة التي نختارها [إسنوان , أشهر , أسبوع, أيام 
ساغات دفائق , اني ...).. اليك هذا المثال: لحساب غد الأبام الي ششناها في هذ الأللية: 


im Lys As Long 
Dayê. DatcDlfMDatclhtcrval. Dayê lA HLFEUALÎ, Haw{)) 
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كنايه اليرنامج 


تستطيع كتابة البرنامج من خلال محرر الأكود البرمجي 


كيفية الوصول إلي محرر الأكود البرمجي 


چ النقر المزدوج : شل النقر المزدوج غل ی أداة فان ذلك سوف پقود يفك ا مترزر 


الكوذ. 
من خلال مسنكشف الحلول 


الأيقونة الأولى من مستكشف الول تقك إلى محرر 


E E 1 e‏ 5 م و ل َة lr‏ و 
الكود كما يظهر من الشكل و الأيقونة التي بجانبها ننقلك إلى وضع تصميم 
1 ا 
موان 
Properties‏ 
Forml System. Windows. Forms.Fo =‏ | 
MEHE‏ 
ج Showlcon True‏ 
ShowlnTaskbaı True‏ 
BH Size 300: 300‏ 
zerp Stylê Ãııto‏ 
StartPosition WindowsDefauıl‏ 
ag 3‏ | 
Test Forml‏ | 
ك Text‏ 
The text associated wıth the control,‏ 
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Serd ta Bacl 


Align to rig 


êk Lontrols 
Select Forml’ 
Ci ۰ 

Loopy 

Pasê 

Delete 


Properties 


وهو ما يمثل واجهة محرر الكود. 


7 FormlLvb’" | FormlLwb [Desig nl 


E Forml lı {(Declarations) 
E Public T1IASS Forrml 


End LTIass 


11 


YOUSSEF 
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وللرجوع لواجهة التصميم 
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با مميزات محرر الكود في بيئة الدوت نت : 

نوجد عدة مميزات لمحرر الكود في بيئة الدوت نت يجدر بك معرفتها لأنها تسيل 

العمل أثناء عملية البرمجة» سوف تتعرض لخمس ميزات منها 
نمط الاختيار المربع : ويمكنك من التظليل الدقيق لما تريد من كود؛ و يحصل عند 
ضغط زر 1ه و تحريك الفارة لأسفل 
اقدریں کچ حت کیا نرت کے رت کرد کی که فا ا 
عرضة و فراجه کل ترنیګچل لثرط و جمل ایی لن اح ب الوم إن 
البحت عن جملة ]1آ وجملة 1٤‏ غ۴15 لوضعيما بوضع ستوازي ضوف تقوم بيئة 
الدت نت بعمل ذلك نيابة غذك. 
كمال الجمل : مئل إكمال تركيب الجمل المشهورة مئل 0ل,11,عووء ]عة 
وغيرهاءو لن تحتاج بعد اليوم إلى حفظ صيغة جملة 1f‏ أو جملة Selec† Cas‏ 
فبمجرد ما نکب جملة 1 نم الشرط نم تقوم بضغط زر ۴11۵۲ سوف تقوم الدوت 
نت بإكمال الجملة نيابة عنك. 
تجز ئ الجمل : مjù‏ خJil Edit 3 Advance %3 Word Wrapping‏ 

غند إعمال هذه المميزة موف تقوم الوت نت بتقسيم الأسطرالطويلة إلى سطرين أو 

أكثر التسهل عملية قراءة الكود. 


ترقيم الأسطر : تتيح لك هذه الميزة.الترقيم الألى لأسطر الكود. 
Tool - Option —- Text Editor - General - All Langeuage — LIne Numbers‏ 


طريقة دقيقة لتظلبل الكود 


PFeiwate Bub Button1l LlickFIEFYTal sender A5 PRFILEM.mjJEztE, Bye 
Dim LONtEEO IAF As Lontrol 
Tor Each <GnErolVar In He.LontEol= 
IF TrpeOf ControlVar I13 TexXFBox 
II TEIMICOHTET TTAE TEHT] = rr | 
erRef.SEtError [Sontrea lVar , 
Fls | 
EFE. SEWEEEDOE lêmtrEo IVA, 


ELA TF 
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الغوابت والتركيات 
الثوابت 


شل افقراضي. الوابت العديا الصعيده بلعامل سيا العنرجم على انها من انوع |٠10۲‏ , والأعاد الشرية من اللوع 
Dollblê‏ 


تيمة نن الںبg Iulejeêr‏ 


F., rT . 1 1 1 
MDNR | أ ا1‎ 
1 1 


تنلمة ين النع 0012 إب.د) 0ط 
ع أك بنك نبد نوع الثات لزيا سرعة إمنا القيب نطب استفدام اللي "1" لنوع وم٠]‏ , اليل "3" لوغ 
hot‏ ,اذ "0" رغ Dea‏ , رالایل "۴" ترم ماو Şin‏ 


IM A, A LON 

¥ = 1 

الإسناد التا يرم ودلك لمدم اجراء التجريز الر امم" ا1001 ! 

لطر الثرابت المسماة ليه بلكرة المتقيرات. إلا أن تيم الراب المسماة !ا يئن تطيلها رت انف رلك لالا تسنبال بلب 

اء شملبة الرجمة لبرنامح: ود دظظها في مف البرنامح النهاني ( ك »ع ما ] اسنضم اللمة المحجرر؛ إو 
ریف ابت جاب 

Lanst HAMU = "aba Univezslty" 


non IMAM |‏ 
نلبد نوع الثابث أمر مفضل ازيادة السر عة بينما بكون إلزامى إن طت العبارة ر ع9 رام 
nat MAF An Arring = " daba niveraity"‏ 
التركيبات 
عبر الزين وسم الأبام؛ سيدا بتعريف راع خاصه بك في براميك الجديه مرل باثركبات ؛ راثي دعنها لغشا المشسبرة غ).۷8 
رة ,رها سانطث فن اهم التريبك رهي ارغ وا و الركييات من نرغ 5111100۲5 كما سافصص لذرة امل حرل 
لمصفرفات رهم وكذلك سحن عن ل من الم الملرفة إوأاة مه ر المجر غك اللرغية عأ٠ع‏ معت . 
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الترکیبات من نوع وہ ںہم 


لسفنڭ تعردف نوع معن من اثواء اتشر اث الى لح تكن فو جودة بالاصسل فى اللفك وتخام أحثتاحاتك الخاصة , نن بسر طف حصسر 
سجال لهذه اليم الئي ستسندها من خلال ما يعرف بالمجاميع المرفمة ( م0ااة۲ ٤نامع‏ ) , وهنا يمنا القبام بذك دن خلال 
استخدم القلمة المحجوزة K0"‏ لتعريف تريب جليد إما على مستوى الوحدة البرمجية #اماكه , أو داخل تركيب أخر ولكن 
من انوع ۲٤‏ ااع 5)٣‏ , كما يجب مراغاة بأنه يمئشنا كتابة هذه القيم باللغة التي نريدها . 


هذا المثال شرف فيه ركيب يمثل ايام الأسبوغ : 

Enum Day 
Saturday 
Sunday 
Monday 
Tudsday 
Wednêsday 
Thursday 
Friday 

End Enum 


والآن يسنك اسنخدام الثركيب السابق ونعريف منغيرات جديدة منه: 


Ûim x As Day = Day.Friday 
تقنيا: تصنف التركيبات من النوع 15٣٠ع ضمن انثوابت فهي كالثوابت المسماة - الئي تطرقت لها سابقا - حبث أن تيمها‎ 
, نستبدل ناء عملية الترجمة‎ 


لم لرل إليها المنقيرات من نفس لوع الأركيب او فيم الأركيب مياشرة: 


ر 


1 Li i i = 
EDS 


Dim A As Day = Day. Friday 
MessageBox.Show(%) 
MessageBox. Show(%. ToString) 
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الترکیبات من نوع یع ںاc su‏ 


يعرف هذا النوع من الذركييات بالالواع المعرفة من فل المسنظم وومر لعم ا0 ٣عولا-‏ (01لا ) , بحبث نمك من دمح 
ألواح مختلفة من المتغيرات وضمها في رئبب أو كتلة راحدة. استظلم الكلمة المحجوزة 51۲1/60۲١‏ لتعريف تركبب جدبد: 


Structure Person 
Dim Name As Strinğ 
Dim Age As Byte 
Endl Structurê 
: لم عرف متغيرات جديدة من هذا الثركيب وتتعامل معها كالمنغيرات العادية‎ 
Lim MS Aş Person 


MS.Name = "Saba" ۹ 
MS.Age = 99 ر‎ 

11 ODES 
NMsgEox( MS.Namê |) Ssaþa : ت‎ 
MsgBox(| MS.Ağê j) ' 99 


المزيد أيضاء يمئنك نسخ فيم التركيبات بانسيابية كاملة كما تفعل مع المتقير اث العادية: شربطة أن تون التركببات متطابقة : 


Lim MSZ As Person 

MSA = MS 
MsqEox(MS2.Name)} ` Saba 
MsgqEox(MS2 Age) ` 99 


لا تنس آن الترگیبات من نوع ٣٥‏ اع ں٣٤5‏ يمكن أن تكون متداخلة ى عاوع آي بحتوي يبعضها بعضا: 


Structure Person 
Structure FersonAddress 
Dim City As String وخ‎ 
Dim Country As String Ml 
eî Sau TEES 
Lim Name As String 
Dim Age As Byte 
Dim Address As PersonAddrêss 
End Structure 
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الوصول إلى تناصر الثركيب المحضون يتم من خلال الثركيب الحاضن لها بئل منطقية: 
Dim ms3 As Person‏ 

mss. Nama = "S323" 

ms3.Age = 99 

ms3.Address. CIty = "Tala" 

= "Republic of Yemen" 


بالاضافة إلى المتفيرات. علبك معرفة أن التركيبات من نوع #إلااع ل٣5‏ في ۷8.8 هي تركيبات مطورة ومرنه جدا جدا 
[ مثل الئركيبات الموجودة في C++‏ ) , فهي نمكنك من تعريف عناصر إطافية في داخل التركيب كالطرق sله‏ ۸ء 
ز الخضانض şعاا‏ عم "ro‏ : 
Structure Person‏ 
ي Dim Name As String‏ 
Dim Age As Byte EERE‏ 
تعريف طريقة أو إجراء 
Sub ShowDatal)‏ 
MsgBox(| Namê & " "& Age)‏ 


End Sub 
End Structure : 
: مرة اخرى؛ يمكنك الوصول الى علاصر التركبب واستعاء طرفة بنفس الطربفة الانسبابية‎ 
Dim MS4 Aş Person 
NS4.Nameg = "Saha" 
NMS4.Age = 99 


MS4 ShowDatal ) 


أن المشيدات 5٣عاع٣اومه٣‏ دعومة بشئل متي في التركيبات من النرع كع اعم حيث أن الإجراء ( New)‏ طاS‏ 
معرف بشكل تلفاني في التركيب دون أن تراه . ولماذا تم اخفانه؟ وما الفاندة منه! الفائدة ببساطة إسناد قيم ابتدانية لمتغيرات التركيب , 
فلو حاولك إساد القيم وفث التصريح تما فعلنا سابقا عند التصريح عن المتغيراث : 

Structure Person 
Dim Namê As String = "Saba" 


DIm Age As Byte = 33 YÊM 


End Structure 
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سيظهر لك المترجم رسال خطاأً تفيذ بأنك لا تسنطيع لعل ذلك وهنا بأئي دور المشيد المخفي إ ]سعل ان5 الي يقرم اساد فد 
بتدائية للمتتيرات [ 0 للمتقيرات الددية: ل شيء للمتغيرات الحرفية: وانقيمة واه للكائنات ) , مع ذلك: يتنك تع يف مشيد 
NW) (‏ ط5 بنفسك عن طريق نطبيق مبدأ بعرف باعااة التعر بف لعل دلك ؛ أضف وسيطات إضالبة مع الاجراء ( ]سم اة : 
Structure Person‏ 
Dim Name As String‏ 
Dim Age As Integer‏ 
Structure PersonAddress‏ 
Dim CIty As String‏ 
Dim Country As String‏ 
End Structure‏ 
Dim Address Aş PersonAddress‏ 
Sub ShowDatal)‏ 
MsgBox(Nameê & " " & Age & " " & Address.City & " "3 Address. Country)‏ 
End Sub‏ 


Name = PêersöonNamÊ 
Age = Person Ajê 
Address.CIty = PersonClty 
Addrêss.CoUuntry = Pêrsön Country 
End Suk 
End Structure 
رغم أن الوظيفة الأساسية نلإجراء ( )عل اباق مي السل کمشید الا آنه لن يئم اسندعانه بمجرد انشاء كائن من الثركيب فيا لو‎ 
صرعت عن متغير جديد بالطرف النقليدية؛ والدليل جرب جذه الأسطر:‎ 
Dir NS5 As Pêro" ` دıيٹڈمنا شا لن بتتلذ‎ 
Ms2.Name = "Saha" 
MS5.Age = 99 
MS5.Address.City = "Taiz" 
NMSS5.Adaress. e = e of Yemen” 
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¢ ¢ ¢ 1 
الإصوات Array‏ 
يمكنك اخبار الفجوال نت بانك تعرف هذا المتغير كمصفوفة بعدة طرق وأشكال أنظر التالي: 


Dim myvalue(5) As Integer 
وهده صورة اخري:‎ 
Dim myvalue(5, 3) As Integer 
عندما تريد ان تضع قيماً بداخل المصفوفة الأولي فيمكنك ذلك بالطريقة التالية:‎ 
Public Class Form1 
Dim myvalue(5) As Integer 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 
myvalue(0) = 11 
myvalue(1) = 4 
myvalue(2) = 13 
myvalue(3) = 44 
myvalue(4) = 123 
End Sub 


End Class 
كما يمكنك تعبئتها بواسطة مهه ] في برنامجك كالتالي:‎ 
Public Class Form1 
Dim mycounter As Integer 
Dim myvalue(5) As Integer 
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 
For mycounter = O0 To myvalue.Length - 1 
myvalue(mycounter) = mycounter 
Next 
End Sub 


End Class 


لأحظ اننا عرفنا متغير من النوع إموهاہا وهو ۲٥ا‏ uںهءرص‏ لاستخدام ه في العد اما العبارة ه۴ فهي ستبدأ من الصفر إلي 
1 - ue.Lengthاmyva‏ و Length‏ تعود برقم يمثل مجال المصفوفة وسوف تعود برقم ٠‏ كما عرفناها ولكنني انقصت منها ١‏ 
لأنه يتم احتساب الصفر أيضاً. 
وبعدها أسندت للمصفوفة علي الترتيب القيمة الصاعدة بداخل المتغير mycounter‏ 
ولكن كيف يمكن التعامل مع المصفوفة من النوع الثاني..؟ 
Public Class Form!‏ 
Dim myvalue(5, 3) As Integer‏ 
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
MyBase.Load‏ 
myvalue(0, 0) = 1‏ 
myvalue(0, 1) = 2‏ 
myvalue(0, 2) = 3‏ 
myvalue(0, 3) = 4‏ 
myvalue(1, 0) = 5‏ 
myvalue(1, 1) = 6‏ 
myvalue(1, 2) = 7‏ 
myvalue(1, 3) = 8‏ 
myvalue(2, 0) = 9‏ 
myvalue(2, 1) = 10‏ 
myvalue(2, 2) = 11‏ 
myvalue(2, 3) = 12‏ 


ا علي كنيفو : تعلم الفيجوال بيسك دوت نت ٠. ٠٠‏ الأصدارة الثانية »۴|6 CHM‏ » المصفوفات Array‏ . 
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myvalue(3, 0) = 13 
myvalue(3, 1) = 14 
myvalue(3, 2) = 5 
myvalue(3, 3) = 6 
myvalue(4, 0) = 17 
myvalue(4, 1) = 18 
myvalue(4, 2) = 19 
myvalue(4, 3) = 20 
myvalue(5, 0) = 21 
myvalue(5, 1) = 22 
myvalue(5, 2) = 23 
myvalue(5, 3) = 24 
End Sub 


End Class 
أنظر هنا قد تم تعبئة المصفوفة.‎ 
طبعاً يمكنك استخدام المصفوفة لأي نوع تريد أنظر للمثال الثإلي:‎ 
Public Class Form!1 
Dim myvalue(5) As String 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 
myvalue(0) = "Visual" 
myvalue(1) = "Windows" 
myvalue(2) = "File" 
myvalue(3) = "Copy" 
myvalue(4) = "Edit" 
myvalue(5) = "Cut" 


End Sub 


End Class 
الأمر واضح تماما وسهل وبسيط جداً.‎ 
Dim myvalue() As String = {"' Visual", "Windows", "File'"", "Copy''} 
أو كما بالشكل التالي:‎ 
Dim myvalue(,) As Integer = {{1, 2}, {3, 4}, {5, 6}} 
ولكن ماذا أذا اردت ان تقوم بتغيير أبعاد هذه المصفوفات» عندها عليك استخدام العبارة "اهم كما بالشكل التالي:‎ 
Public Class Form! 
Dim myvalue(5) As Integer 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 


ReDim myvalue(0) 
myvalue(0) = 1 


End Sub 


End Class 


لقد عرفت مصفوفة من خمس اعمده ان صح التعبير تم في اأ Form_ load‏ أستخدمت ص لم8 لأعادة تعريفها بعمود واحد فقط 
ولو حأولت ان تضيف عليها فستحصل علي رسالة خطاء. 
وبالمثل يمكنك استخدام هذه الطريقة مع النوع الثاني من المصفوفات. 
اذا اردت ان تعرف ابعاد المصفوفة فيمكنك استخدام الأمر الثإلي: 
Public Class Form!‏ 
Dim myvalue1(5) As Integer‏ 
Dim myvalue2(5, 5, 6) As Integer‏ 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
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MyBase.Load 
MsgBox(myvalue1.Rank) 
MsgBox(myvalue2.Rank) 


End Sub 


End Class 
وبالرسالة الثانية ستحصل علي الرقم ثلأثة‎ ١ حيث بالرسالة الأولي ستحصل علي الرقم‎ 


كما يمكنك تحديد القيمة المعطاة اي الرقم المحدد في تعريف المصفوفة انظر التالي: 
Public Class Form!‏ 


Dim myvalue1(5) As Integer 
Dim myvalue2(5, 5, 6) As Integer 


Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 


MsgBox(UBound(myvalue1)) 
Msg Box((myvalue2.GetUpperBound(2))) 


End Sub 

End Class 
بالرسالة الأولي» وستحصل علي الرقم  بالرسالة الثانيةء ولأحظ اننا حددنا رقم الخانة المراد قراءة‎ ٠ ستحصل علي الرقم‎ 
لأنها تحتوي علي ثلأث خانات.‎ ۲-٠-١ قيمتها وهي ۲ أي انها‎ 


كيف يمكن عرض ما بداخل المصفوفة...؟ 
كما استخدما ×ط وء" يمكنك استخدام أي اداة لنفرض ×هط×ه٠‏ أنظر إلي الشكل التالي: 
Public Class Form1‏ 
Dim myvalue1(5) As Integer‏ 
Dim myvalue2(5, 5, 6) As Integer‏ 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
MyBase.Load‏ 
TextBox1.Text = myvalue1(3)‏ 
TextBox2.Text = myvalue2(3, 2, 5)‏ 
End Sub‏ 


End Class 


أو العكس يمكنك ان تضع بالمصفوفة قيم من الأداة > طا»×ه٣‏ أو اي أداة أخري لأ فرق. 
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الجرء الرايح : نطيذات مسوعه 
كيفية عمل متصفح الإنترنت 
كيفية عمل متصفح من خلال برنامج الفيجوال بيسك دوت نت2005 
قم بفتح البرنامج كما تعلمنا معا بالدروس السابقة وأتبع كما هو موضح بالأشكال التالية 


New Project 


Templates: 


Visual Studio installed tem plates 


Windows Llass Library  Lonsole Application My Movie Collection Screen Saver Starter 
Application Starter Kit kit 
My Templates 


Search Onlinê 40 USSR 


Templates... 


A project for creating an application with a Windows user Interface 


Marie: web browser 


lse) | Lancel 4 


۰ mêl Forml 
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2 
YOUSSEF 


قم بتغيير حجم النافذة " بيئة المشروع " إلي ما يناسبك أو بأمكانك جعل بيئة العمل تظهر بملء الشاشة وذلك بأتباع ما هو 
موضح بالأشكال التالية. 


Forml System. Windows, Fortms,Fo * 


AEE 
StartPositflon WindowsDefaul & 
Ta 
Text Forml 7 

Toplost False EEE 


Transparencyk 


من صندوق الأدوات أختر ما هو موضح بالأشكال التالية. 


Prog: Mohamed Youssef ۰۴۳ E_Mail: Mohamed.yoyo@gmail.com 


وقم بأضافة تلك الأداة كما تعلمنا معا بالدروس السابقة إلي بيئة العمل ليصبح كما هو موضح بالشكل التالي 


هل لأحظت ما حدث به فضلا أخبرني بما حدث ؟ 


من صندوق الأدوات أضف الأداة المشار إليها بالشكل التالي 


Prog: Mohamed Youssef 1۰٤ E_Mail: Mohamed.yoyo@gmail.com 


ا 


| EF Web Brows êr 


ليصبح شكل العمل كالتالي 


قم بأضافة الأدوات المشار إليها بالأشكال التالية 
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E ComboBox 
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قم بأضافة الأدوات التالية وقم بتسميتها بتلك الأسماء 

Refresh ¢! Button2 
Stop ¢! Button3 
Back Jİ! Button4 

Forward !ئي‎ Button5 

قم بتسمية الزر الذي بجوار المكان الذي يوضع به الروابط 1ل ه† ه6 
الأكواد 
الزر الأول ضع له الأكود البرمجي التالي بمحرر الأكود البرمجي 


الكود البرمجي: 


WebBrowser1.Navigate(ComboBox1.T ext) 


Refresh 


الكود البرمجي: 


WebBrowser1.Refresh() 


Stop 


الكود البرمجي: 


WebBrowser1.Stop() 


Back 


الكود البرمجي: 


WebBrowser1.GoBack() 


Forward 


الكود البرمجي: 


WebBrowser1.GoForward() 


يمكنك أيضا إضافة بعض المواقع المفضلة لك لتصل إليها بشكل أسرع دون كتابتها. 
لعمل ذلك قم بالضغط علي أداة حمط ماه الموجودة علي الأداة مجم و اضغط علي الثلأث نقاط الموجودة بحانب 
الخاصية.ء"٠]!‏ 

ستظهر لك نافذة › اكتب فيها مواقعك المفضلة (كل موقع في سطر) 


صف ر آخر إلي الأداة امرPa‏ و غير الخاصية 1٥×‏ الي yİSave web page‏ أي نص ترید إظهاره علي الزر يدل علي عمله 
انقر نقراً مزدوجا علي هذا الزر 
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الكود البرمجي: 


WebBrowser1.ShowSaveAsDialog() 


04 4 


كذلك يمكنك فتح صفحة قد قمت بحفظها .أضف زر آخر الي الأداة امم هم و غير الخاصية Open Jİ! Text‏ و أضف أداة أخري 
من قائمة الأدوات و هي الأداة وماه5ءاأ۴"مم0 في قسم ووه‌اها في قائمة الأدوات 


ملحوظة: ضع الأداة OpenFileDialog‏ في أي مكان من الفورم لأنها في كل الأحوال لن تظهر للمستخدم حيث أنه في اموا 
اasic.neطهناك‏ بعض الأدوات غير مرئيه تظهر للمبرمج فقط ليستخدمها لكنها لن تظهر للمستخدم. 
انقر علي الزر نقراً مزدوجا و اكتب: 


الكود البرمجي: 
OpenFileDialog1.ShowDialog()‏ 


WebBrowser1.Navigate(OpenFileDialog 1.FileName) 
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کیفیه عمل کتاب الکتروني 0۴ م٥‏ 
١‏ فیجوال بيسك دوت نت ۲۰۰٣‏ 
1- اي اصدlر‏ nڻAcrobatj Adobe‏ 


رة الل 
أولاً افتح البرنامج 

Microsoft 

Visual StUdÎO 2005 


Professional Edition 


This product is licensed ko: Installed Products: 


egyptian hak. دي‎ ™e| Microsoft Wisual Basic 
Hamê 2 


: Fl Microsoft Wisual C# 


EN a 
TV ODSSEF A Microsoft Visual LFF 


This program is protected Dy Urs, ft Microsoft Visual 1# 
and Intemational copyright lays 


a3 described in Helplêbout, TH Yisual Web Developer 
@ ZOOS MicrasoR Corporation, 


ûll rights reserved, J Crystal Reports 


ثانيا 
نفتح عمل جدید 


File Wiy Tools Window Lommunit Help 
Project 7 LtrlrShirt+N 
pen # website... 
LISE” E gt 
EL Clase Salation Project Frarn Existing Lodê, 


نختار المحدد بالصوره (جاهل أنجليزي) 


Hew Project 


Project Cypes: Templates: 


la: اھا‎ Basic Yisual Studio installed templates 


HH. Smart DEP E] windows Application IGE Class Library 
: GDatabase . ER Zonsolê Application E] windows Loantrol Library 
i. SEarter Kits e e] web Control Library JE] windows Service 
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Hl Yisual Z++ My Templates 


BH: Other Project Types . 
3 iloearch Online Templates... ي‎ 


YOUSSEF 


ûn ermpty project For creaking a local application 
Hame: Projectî 


Location: Documents and Settings 11My DocumentsiYisual Studio ZUDSYProjecEs اا‎ 
salutian Mame: Projects Lreate directory For solution 
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رابعا 


» 


ننشئ فورم جدید كما بالصوره 


solution Project 1 ÊÊ‏ ا 
E.‏ ا 


Rebuild 
lean 


Publish... 
o 


1 | Add Reference, ,, 


Mem Iter... 


| Existing Iter... 


Add Web Reference, ,, 


: Mem Folder 


Windows Form... I Yiew lass Diagram 


. User Lontral,,, el a5 SLartLlp Project 
` Component, 
1 Module... 


lass... 


Pol 
Poi 
Frat 


i E 


Lnload Project 


zz) Properties 


نختار المحدد 


Add New ltem - ProjectB 


Templates: 


Yisual Studio installed templates YOUSSEF 


Tinos Forrii ود ادا‎ “>: Explorer Forrn 
E | MDI Parent For ا‎ About Bi نو ا‎ Farr 
[=| Splash Screen * E] lass £] Module 
ê Interface cB] Component Class Ê LOM Class 
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aA Resources File E] Seti file e | ode File 
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#SLT File 2 Text File 5 HTML PagğE‏ ا 
ıa Bitmap File |b | Cursor File ۳ Icon File‏ 

E3] Application Configuration File ا‎ Transactional Camponern™ 8 Installer Class 
HE] Windows Service 
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الأن طريقة تصميم البرنامج 
أولا. 
اصنع مثل هذا الشكل 


قارئ كتب إهداء ال كتاب العرب 5 | 


YOUSSEF 


ثانا 
٥‏ اضغط كلك يسأو اختر المحدد بالصورة 
E Date TimePicker :‏ 
Label‏ 


جي ا 


LinkLabel | 3  Zopy 
ListBox 


LIEYE x Delete 


IIE | 
I : 
ı4 EB 


1 | ر 


س 
1 
"را 
Mi‏ 
ù‏ 
Û‏ 


T7 


lêl Mumericl 


Sart Iterns Alphabetically 


Reset Toolbox 


labl| TextBox Add Tab 


i ToolTip Move Up 


a [reee Mowe Doryr 


ثالتا 
اختر الأداة المحدد 
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Choose I[oolbox Items 


JarîE / ۴ Path Library 
[Î 3 YidenSaft Flex Arr a LINO SYSteErmSA\WSFLERS OLN :- WideoSofFE ¥5, ,, 
1 LIMOS SteEmSAYSFLENS. OLN. 4 videoSoFE ¥5, ,, 
LIMOS YSsteEmSA mrt, dll 
Documents and Settings 11Deskto,,, ActiveSkin 4.0٠... 
LC YINOTWS SSE SaA plugin, DEX Microsoft Acti¥ê,.. 


WINDOWS YStEemSalrmnrt , dll 
LIMOS StEMSA\MSA#N DCX 


Adobe Acrobat 7.0 Browser Docu,,., LH Prograrn FilesiAadobeûcrobakt 7.0... Adobe Acrobat ,.. 
[Î BrowserProxy4 Class LW OTWSISYSteEMSA ATE] . dl AlETE 1.0 Type 
[| Calendar Control 11,0 Program Files\Microsoft OFFiceOF.,,, Microsoft Zalen E 


3 [1 | 5 | 
J YideoSaft Flex Ara! 
rer E 


` 0 
OUI 


رابعا 
ضعها علي الفورم كما بالشكل 


رخ کنب إعداء الے گتاب العرب اک 
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خامسا 
اضغط علي زر إقرأً مرتين وضع هذا الأكود البرمجي 
الكود البرمجي. 


AxAcroPDF1.LoadFile('"D:/arabsbook.pdf'"") 


شرح الأكود البرمجي 
ي انه عند الضغط علي زر إقرأ يقوم بفتح ملف لم.)0هطءطهج الموجود علي قرص ل في خانه 5۴1 ۸×۸٥‏ التي قمنا 
بإضافتها اضغط 5 واضغط علي إقرأ 


قاری كتنب إهداء الى كتاب العرب إ۹ 


e © 7% :‏ | 5 1 0 غ هھ رج 


Atachments: 


ا 
ا 
1 
ج 
ع 
- 
ےا 


YOUSSEF LL 


4F E SEI 


الأن احفظ العمل بصيغة عادية عن طريفقَةً م۷رهء 


اذهب إلي مكان تخزين المشروع وافتحة تجد مجلد في داخلة اسمةہ ام 
افتحة تجد مشروعك بصيغةم×م 


ويکون احيانا في 

C:\Documents and Settings\1\My Documents\Visual Studio2005\Projects\Project7\Project7\bin\Debug 
Prهزمc]74مسا اذ کان‎ 

الان زر اهداء 


" ×0 طاوءصإهداء إلي منتدي تكنوبلوجيا التعليه" 


زر تصميم 
" ×0 وء" تصمیم محمد یوسف " 
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قم بفتح البرنامج وأدراج بيئة العمل كما تعلمنا معنا بالدروس السابقة 
ومن نافذة الخصائص غير القيم التالية كما هو موضح بالشكلين التاليين 


پڪ 
Forml System. Windows. Forms.Fo * |‏ 


dz | E # |E 
StarftPosition Winclojyflle 

ا 2 

Text 

Toplost False 
Transparencyk Û | 


ا ا 


| LIseWaitCursor False 


۳ 2 
| Forml System. Windows.Faorms,.Fa =” | 


EEE 
MinımızeêBox [rue 
E MinmurmSize Û: Û 
pacity IE 
Padding J: Û: Û: Û 
RightToLeft Yes e 
.  FıghtTalLeftLay True 1 


Showricon True 


E > FF ل‎ 


ليصبح النموذج النهائي لبيئة العمل كما بالشكل التالي 


اه الال الحاسبا 


قم بأدراج المكونات التالية إلي بيئة العمل كما بالشكل التالي 
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الاي الحاسبة 1 


RadioButton Û) 


RadicButton3 


RadicEButtornıt | 


س 


Label3 
OMESEF 


وقم بتحديد المسيمات كما بالشكل التالي 


الرقم الأول 


SSE 


وقم بأضافة زر تنفيذ كما أشرنا سلفا 


ثم قم بالضغط علي بيئة العمل الرئيسية ليظهر محرر الأكود البرمجي ضع الشفرة التالية كما هوموضح 


Prog: Mohamed Youssef 11° E_Mail: Mohamed.yoyo@gmail.com 


Uata Tools 


j + 


Winco Help 


ESET 


| Î [Declarations] E 


3 


ر 


LommuInity 


Ë چ‎ | 


Lim FirstMNum, SecCconANMum As Doub 1e] 


Private Bub Forml Load{EBYVaLl sender As PRystem. Object, Bfval e As Satem . Er 


ا 
ا ا 


End Sub 


Debug 


a Forml‏ ا 
APubIlic Class Forml‏ 


® 


Form1.vb" | Form Lyb [Design] Start Page | ] 


ا 


4 End LILIass 


1 


YOWESEF 


II 8 | 


Lı 2 


E WindowsApplication 1 - Mifefosoft VisûAlLBasıc 2005 Express Editiqrî 


File Ect View Project Bunld 
ê EH | # E 
| Taolbox TN F*K 
All Windows Forms 


ener al‏ ك 


There are no usable controls In 
thıs qroup. Dragcy an Item onto 
thıs text to aclel If to the toolbox. 


Realy 


Fa Empiess. Hirbiop 


E inda pplication Û - Eto Vruadl Far iE 


Leta 


ا ٣‏ کا د 


Tia Tal Winda Canim Help 

e 0‏ کک کک ج 3[ n‏ + ات ا تت 
Fa aL." Faia kula [Dt gj | Sal Page TK‏ 
a rr :‏ : ن Erika‏ : 


El FOLIA 
EEE TE ml E OT Tala i ET EE ml mR 


Friar Bub Focml: Lod | ByIs1l menfeet hs EpeteEm.lh ier; Bal e le Egateh, BE 


En 3ub 

Friwat” Fr EEO CR icETBEFaL sender 
Firatim = Tet lrnr1] . Tek 
ean = Tet Enz È . Text] 

Ed 3ib 

TTF | 


ka Syke. hj emnkl, Byisal & 1 غ8‎ 


آ ا 


ثم قم بوضع الشفرة المشار إليها سابقا 
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1 Broan | 


FLEE 


Erî 


FE Ed 


و ل 


rî PFagert Enki 


غ ا 


ا زق ةا وف اقا ق 
آ ا اف 


There û û ablê carîoÈ mı 
Phi FE I FET aR Fart SRE 
hia te û adel # ta he Foalleott 


| Res. ir 1 “al 24 


Prog: Mohamed Youssef 


وهذا تطبيق أخر لأنشاء الة حاسبه متطورة 


EE Faormîl 


Dim clearDisplay As Boolean 

Dim Operand1 As Double, Operand2 As Double طbبضئlبو هنا تكتب الأكواد في اعلي الصفحة‎ 
Dim [Operator] As String! 

تحت كلم اأ public class‏ 


زر رقم واحد 


الكود البرمجي: 


Private Sub bttn1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
bttnO0.Click, bttn1.Click, bttn2.Click, _ 
bttn3.Click, bttn4.Click, bttn5.Click, bttn6.Click, bttn7.Click, bttn8.Click, bttn9.Click 


If clearDisplay Then 

IbIDisplay.Texit = '"'" 

clearDisplay = False 

End If 

IbIDisplay.Text = Val(lbIDisplay. Text + sender.text) 
End Sub 


ولأحظ كتابة اسامي الأزرار في الكود البرمجي واحد 
الكود البرمجي زر الفاصله في الأرقام 


الكود البرمجي: 


Private Sub bttnPeriod Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttnPeriod.Click 


If IbIDisplay.Text.IndexOf(".'") > 0 Then 


Exit Sub 

Else 

IbIDisplay.Text = IbIDisplay.Text & '"'." 
End If 
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(+) الجمع الكود البرمجي زر 


Private Sub bttnPlus_ Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 


bttnPlus.Click 


Operand1 = Val(IlbIDisplay.Text) 
[Operator] = "+" 

clearDisplay = True 

End Sub 


الكود البرمجي(=) 


الكود البرمجي: 


Private Sub bttn Equals Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttn Equals.Click 


Dim result As Double 
Operand2 = Val(IlbIlDisplay.Text) 
Try 

Select Case [Operator] 

Case "+" 

result = Operand1 + Operand2 
Case "-" 

result = Operand1 - Operand2 
Case '"*" 

result = Operand1 * Operand2 
Case "/" 

If Operand2 <> "0" Then IblIDisplay.Text = result 
End Select 

Catch exc As Exception 

Msg Box(exc.Message) 

result = "ERROR" 

Finally 

IbIDisplay.Text = result 
clearDisplay = True 

End Try 

End Sub 


الكود البرمجي: 
(-) الكود البرمجي عملية الطرح 


Private Sub bttnMinus_ Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttnMinus.Click 


Operand1 = Val(lbIlDisplay.Text) 
[Operator] = "-" 


clearDisplay = True ' IbIDisplay. Text = 


End Sub 
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(*) الكود البرمجي عملية الضرب 


Private Sub bttnMultiply_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttn Multiply.Click 


Operand1 = Val(IlbIDisplay.Text) 
[Operator] = '"*" 
clearDisplay = True 


End Sub 


(/) الكود البرمجي عملية القسمه 
Private Sub bttnDivide_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)‏ 
Handles bttn Divide.Click‏ 


Operand1 = Val(IlbIDisplay.Text) 
[Operator] = '"/" 
clearDisplay = True 


End Sub 


اكتب هذا الأكود البرمجي في ال ]٥۲٠/_‏ وغير الخاصية من 
Form_load ¢! form_keypress‏ 


Private Sub Form_KeyPress(ByVal sender As Object, ByVal e As 
System.Windows.Forms.KeyPressEventArgs) Handles MyBase.KeyPress 
If System.Char.IsDigit(e.KeyChar) Or e.KeyChar = "." Then 

If clearDisplay Then 

IbIDisplay.Texit = ''" 

clearDisplay = False 

End If 

IbIDisplay.Text = IbIDisplay.Text + e.KeyChar 

End If 

End Sub 


الكود البرمجي زر المسح في مربع النصا×ه١.رهامءiداطا‏ 


Private Sub bttnClear Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
bttnClear.Click 


IbIDisplay.Text = 
End Sub 
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۰ EE Game 


[ Button 


O standard (O advanced 


ص 


C Rad ButonT TJ [ RadoBurton2 


Public Class Form1l 


Private Sub Buttonl1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
If RadioButtonl. Checked = True Then 
a = 1 
Else 
a= 2 
End If 
Form2. Show () 
End Sub 


Private Sub Forml1 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
RadioButtonl. Checked = True 
Buttonl . Select () 
End Sub 
End Class 
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EE Game E 5 


[ Butstart | ا‎ | 


| Butpress ا‎ 


f ibihits | 


Timerl Timer 


Public Class Form2 
Dim hits As Integer = 0 
Private Sub Form2 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
Me. Timerl.Enabled = False 
Me. Timer2.Enabled = False 
Me. Butpress.Enabled = False 
End Sub 


Private Sub Butstart Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Butstart.Click 
Select Case a 


Case 2 
Me. Timerl. Interval = 1000 
End Select 
Me. Timer1l.Enabled = True 
Me. Timer2.Enabled = True 


Me. Butpress.Enabled = True 
Me. Butstart. Enabled False 
End Sub 


Private Sub Butpress Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Butpress.Click 
hits = hits + 1 
Me. lblhits. Text = Format (hits, "Number of hits = # ") 
End Sub 


Private Sub Timer2 Tick (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Timer2. Tick 
Me. Timerl1l.Enabled = False 
Me. Timer2.Enabled = False 
Me. Butpress.Enabled = False 
Me. Butstart. Enabled = True 
End Sub 


Private Sub Timerl Tick (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Timerl. Tick 
Randomi ze () 
Me. Butpress.Left = 200 * Rnd() 
Me. Butpress.Top = 200 * Rnd() 
End Sub 
End Class 
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كيفية حساب الزمن بالثانية من آي تاريخ ' 


Date Calculator 


Date Lalculater 


ListBox 1 


[Datetimepicker1 


8 ,ر نوقمیر_03. 
Listbox1‏ 
LInik‏ 
OTE,  _ RadioDays‏ 
Hours _ Radiohours‏ ( 
RadtioMinutes‏ 


ا ا ی 
Laleulaker 0 Radioseconds‏ : 
Buttortr‏ | 


Public Class Form1l 
Dim a As Integer 
Dim d As Long 
Private Sub Radiodays CheckedChanged (ByVal sender As System.Object, ByVal e 
As System. EventArgs) Handles Radiodays. CheckedChanged 
a = 1 
End Sub 


Private Sub Radiohours CheckedChanged (ByVal sender As System. Object, ByVal e 
As System. EventArgs) Handles Radiohours. CheckedChanged 
a= 2 
End Sub 


Private Sub Radiominutes CheckedChanged (ByVal sender As System. Object, ByVal 
e As System.EventArgs) Handles Radiominutes. CheckedChanged 
a= 3 
End Sub 


Private Sub Radioseconds CheckedChanged (ByVal sender As System.Object, ByVal 
e As System.EventArgs) Handles Radioseconds. CheckedChanged 
a = 4 
End Sub 


Private Sub Buttonl1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
Select Case a 

Case 1 
d = DateDiff (DateInterval.Day, DateTimePickerl. Value, Now) 
ListBoxl. Items. Add ("the difference " & d & " Day") 

Case 2 
d = DateDiff (DatelInterval. Hour, DateTimePickerl. Value, Now. Date) 
ListBoxl. Items. Add ("the difference " &€ d &€ " Hour") 
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Case 3 
d = DateDiff (DateInterval.Minute, DateTimePickerl. Value, 


Now. Date) 
ListBoxl. Items. Add ("the difference " & d &€ " Minute") 
Case 4 
d = DateDiff (DatelInterval. Second, DateTimePicker1l . Value, 
Now. Date) 
ListBoxl. Items. Add ("the difference " & d & " Second") 
End Select 
End Sub 


Private Sub Forml1 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
DateTimePickerl1l. ShowCheckBOx = True 
Me.Text = "Date Calculater" 
Buttonl. Text = "Calculater" 
Radiodays. Checked = True 
Buttonl. Select () 
End Sub 
"Programming Mohamed Ahmed Youssef 
End Class 
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كيفية تصميم جدول الضرب المتطور 


Multiplication Examiner 


Hl Multiplication Examiner - 


This application will help ¥ouı to learn muutiplication . 
| Standard leyel is used for 12*12 mulitiplication table. 
Poderate level is used for mulitiplication of 2Z diqit numbers. | 


Advanced level is used for multiplication of 3 digit . 


¶ TextBox! 


/ Standard 
(O Moderate 


J AhdlYanced 


f Buttont 


Public Class Form1l 


Private Sub Button1l Click (ByVal sender As System.Object, ByVal e As 


System. EventArgs) Handles Button1l.Click 

If RadioButtonl. Checked = True Then 
a = 1 

ElseIf RadioButton2. Checked = True Then 
a = 2 

Else 
a = 3 

End If 

Form2. Show () 

End Sub 


Private Sub Forml1 Load (ByVal sender As System.Object, ByVal e As 


System. EventArgs) Handles MyBase. Load 
Buttonl . Select () 
RadioButtonl. Checked = True 

End Sub 

End Class 
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Multiplication Examiner 


| textboxa 
|The Result of multiplication 7 by 5 =_ . 


| textbox | ( Buftonî [submit | 


Plase Enter the Result 


پل 


ETT Bufton# [ New Yalue | 


Public Class Form2 
Dim nl, n2 As Integer 
Dim r1, r2 As Integer 
Private Sub Form2 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
Buttonl . Select () 
TextBox3. Text = "Plase Enter the Result" 
Select Case a 
Case 1 
Randomi ze () 
n1 = 1 + 10 * Rnd() 
n2 = 1 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy FEF COSEr(NnZ) LT 
TextBOox2. Text = '""" 
Case 2 
Randomi ze () 
n1 = 15 + 10 * Rnd() 
n2 = 15 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy "TF COSEI(NZ) 1T =< 
TextBOox2. Text = '""" 
Case 3 
Randomi ze () 
n1 = 100 + 10 * Rnd() 
n2 = 100 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy TT FT CESEE(NZ) FG TT >IT 
TextBOx2. Text = '""" 
End Select 
End Sub 


Private Sub Button2 Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button2.Click 
Buttonl . Select () 
TextBox3. Text = "Plase Enter the Result" 
Select Case a 
Case 1 
Randomi ze () 
n1 = 1 + 10 * Rnd() 
n2 = 1 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy " Ff CSEE(NZ) FT =1 
TextBOx2. Text = '""" 
Case 2 
Randomi ze () 
n1 = 10 + 10 * Rnd() 
n2 = 10 + 10 * Rnd() 
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TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
By TFT CESED FG TT OT 
TextBOx2. Text 
Case 3 
Randomi ze () 
n1 = 100 + 10 
n2 = 100 + 10 
TextBoOxl. Text 
by " + CStr(n2) + " = " 
TextBOx2. Text 
End Select 
End Sub 


rr Ir 


Rnd () 
Rnd () 
"The Result of multiplication " + CStr (n1) + " 


* »* 


rr Ir 


Private Sub Button1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
r1 = n1 * n2 
Try 
r2 = TextBOox2. Text 
If r1 = r2 Then 


TextBox3. Text = "congratulation , True Result" 
Else 
TextBox3. Text = "Sorry ,Wronge Result the True Resulte " + 
CSEE(EI) FET 
End If 


Catch ex As Exception 
MsgBox ("Enter the answer") 
Exit Sub 
End Try 
End Sub 
End Class 
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كيفية تصميم أختبار خاص بأعلام الدول 


Flags Examiner 
El Flags Examiner Fomî | SEES 


(PictureBox | 


أختر إجدك الدول 
If Button‏ 5 
er) Ba)‏ 


1 سنن 


| hoose the name of country which laq is shoyyn aboye. 


| 1 Right Answers Wrong Answers ا‎ | 
۹ kk 


TextBox2 J) (Labelî | (Tabel2 | (exo 


You have to copy contents of subdirectory 1mages into C:\i1mages 


Public Class Form1l 
E E vT TG yS 
'w=Wrong Answer 
'r=Right Answer 
Dim r, w As Integer 
E E 
Dim a As String 
N N TS 
Dim nameflage As String 
Private Sub Forml1 Load (ByVal sender As System. Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
E I OC E SS EET 
With ComboBox1l 
. Items. Add ("lıil.wا‎ ”") 
. Items. Add ("lull اښسشتر‎ ”) 
. 1tems. Add ("اuقيرفا_هيبونحجلا‎ "( 
. Items .Add ("jدرڻٺل|‎ ”") 
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.Add ) الامار ات"‎ "( 
. Add) البرازيل"‎ "( 
.Aككل)"رثئازجلا‎ "( 
.Add( uo ll ") 
. Add ) الصن"‎ "( 
.A2202)"ةارعلا‎ "( 
. Adك‎ ) الكويت'"‎ "( 
. Add الجر"(‎ "( 

. Adك‎ ) المغرب"‎ "( 
. Add الهند")‎ "( 
.AQdd( SIL NSN oI) 
A22 ) ال انان"‎ 4) 
.Aكdلdل إليمن")‎ 4) 
.Add ) اير ان"‎ "( 
.AQdA( IN N) 
Ada CIS IS TT) 
AdA( lS ILE) 
. Add) ("تونس'"‎ 
.Add("اuسور‎ "( 
.Add("ايروس"(‎ 

. Add عمان"(‎ "( 

("فلسطن" ) كAd‏ . 
("قطر" ) Add‏ . 
(" الجنوبيه_كوريا")ككA.‏ 
("”لبنان"( Add‏ . 

. Add ("ليريا"(‎ 

. Add ليبا"(‎ ( 


. Add)" ("مصر‎ 
— Mw أ‎ 


ختر ا" = 


e‏ إحدي 


. [tems 
. [tems 
. [tems 
. ITtems 
. [tems 
. [tems 
. [tems 
. [tems 
. Items 
. [tems 
. ITtems 
. [tems 
. [tems 
. [tems 
. [tems 
. Items 
. [tems 
. [tems 
. [tems 
. [tems 
. ITtems 
. [tems 
. [tems 
. ITtems 
. Items 
. [tems 
. [tems 
. [tems 
. Text 
.RightToLleft = Windows.Forms. RightToLeft. Yes 
.ForeColor = Color. Red 


End With 

Strech‏ الصور صندوق في مليئة الصورة عرض جعل' 

PictureBoxl.SizeMode = PictureBoxSizeMode. Stretchlmage 

TextBoxl. Text = "Choose the name of country which flag is shown above." 
ND E E E GS E ET 


Call Flageshow () 


End Sub 


Private Sub Button1 Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1.Click 


E N N GT 
Call Flageshow () 
ComboBox1. Text = "jzخ|‎ يaدحإ الدول‎ 
TextBoxl. Text = "Choose the name of country which flag is shown 
r= 0 
TextBox2.Text = r 
Ww = 0 
TextBox3. Text = w 
End Sub 
Private Sub Button2 Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button2.Click 
E TS 
a = ComboBox1l . Text 
If PictureBox1. ImageLocation = ("c:\images\" + a + ".png") Then 
TextBoxl. Text = "Congratulations. Right result . " 
FEF = FF FI 
TextBOox2.Text = r 
Else 
TextBoxl. Text = "Sorry.Wrong answer. The right country is " + 
nameflage + " ." 
Ww=w + 1 


TextBOx3. Text 


1 
3 
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TIF 


End 
End Sub 


Private Sub Button3 Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button3.Click 
E E GE e ST 

Call Flageshow () 


ComboBox1. Text = "jzخ| الدول إحدي‎ 

TextBoxl. Text = "Choose the name of country which flag is shown above. " 
End Sub 
ا ارا‎ 


الصضور مرنح فق E E e‏ ف الكدول 


. Load ("c: \|images\laılJ| رîwا‎ .png") 


. Load ("c:\images\|Jaıjlرıل|‎ .png"”) 


. Load ("c: \images\jaJlا‎ .png") 


. Load ("c:\images\jliılJ.png") 


. Load ("c: \images\دıiqd!‎ .png") 


. Load ("c: \images\|اI‎ ıilرııيا‎ .png"”) 


. Load ("c: \images\ا‎ ıilwıl! .png") 


. Load ("c: \|images\lıJlطıl‎ .png”") 


. Load ("c:\images\jlبlıl|‎ .png") 


. Load ("c: \|images|laرgك_aيبونجz‎ è ال‎ .pn9"( 


. Load ("c: \images\|ٽıيgSJا‎ .png") 


. Load ("c:\images\lıyuJ.png") 


. Load ("c:\images\lıwو ر‎ .Png") 


. Load ("c: |images|laقتيرفا_وۈەيبونجلا‎ .pn 9" ( 


" الجنوبيه_افريقيا" 


. Load ("c: \images\|lailıw! .png") 
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عشو ائي تترتيب في 


E rr 


البرازيل" 


UR 0 rr 


ll . 1 2 


ا 


ET 


1 لك ا 


4 | 0 |44 


GEES 


ا 


E < 2 


Ws 2 


E ا‎ 


4 | | 1 


۱۲۹ 


Sub Flageshow () 


ضور عد د ا ي 
Dim n As Integer‏ 
الاعلام وضع' 


Randomi ze () 
n = Rnd() * 26 
Select Case n 


Case 1 
PictureBox1 
nameflage = 

Case 2 
PictureBox1l 
nameflage = 

Case 3 
PictureBox1 
nameflage = 

Case 4 
PictureBox1 
nameflage = 

Case 5 
PictureBox1l 
nameflage = 

Case 6 
PictureBox1 
nameflage = 

Case 7 
PictureBox1l 
nameflage = 

Case 8 
PictureBox1l 
nameflage = 

Case 9 
PictureBox1 
nameflage = 

Case 10 
PictureBox1l 
nameflage = 

Case 11 
PictureBox1l 
nameflage = 

Case 12 
PictureBox1l 
nameflage = 

Case 13 
PictureBox1l 
nameflage = 

Case 14 
PictureBox1 
nameflage = 

Case 15 
PictureBox1l 
nameflage = 

Case 16 
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N TS 
. Load ("c: \images\wrong. png") 
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. Load ("c:\images\|تlيllوgلاl_هoدحجتهنا‎ .pPn3"( 


E TT 


. Load ("c: \images\|رطi.png")‎ 


rr 1 د‎ rr 


. Load ("c: \images\J| رaJ|‎ .png”") 


2 ا 


. Load ("c: \images\ ر¬..png")‎ 


rr rr 


مصر 


. Load ("c: \images\jaıl! .png") 


ا ° MN‏ 
ء * 


. Load ("c:\images\jدراl!l‎ .png") 


ON rr 


. Load ("c: \images\| jlne .png") 


rr‏ ا 


.Load("c:\images\lıر‎ yw .pPng") 


ES 


. Load ("c: | images |jطwJi.png")‎ 


< 1 1 3 


. Load ("c: \imagesl\رiاl‎ j| .png”") 


EET rr 


.Load("c: \imagesl\i! lanl .png") 


N 1 


ل 


PictureBox1l 
nameflage = 
Case 17 
PictureBox1l 
nameflage = 
Case 18 
PictureBox1l 
nameflage = 
Case 19 
PictureBox1l 
nameflage = 
Case 20 
PictureBox1l 
nameflage = 
Case 21 
PictureBox1l 
nameflage = 
Case 22 
PictureBox1l 
nameflage = 
Case 23 
PictureBox1l 
nameflage = 
Case 24 
PictureBox1l 
nameflage = 
Case 25 
PictureBox1l 
nameflage = 
Case 26 
PictureBox1l 
nameflage = 
Case Else 


إلي الوصول حالة فيا 
PictureBox1l‏ 
End Select‏ 
End Sub‏ 
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End Class 
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الجزء الخامس: التعامل مح قواعد الببانات 


SQL Server 2005 چمliرڊ شرح‎ 


اقدم لكم سلسة من دروس فيجوال بيسك ٠٠٠٠١‏ و 5012005 للمبتدئين 

بداية اتناول في هذه السلسلة بعض المواضيع المهمة ولأ اتطرق كثيرا في شرح المغيرات والمصفوفات والعمليات الحسابية 
وانما امر عليها سريعا. 

واعتمد في دروسي علي التطبيقات حيث يتم عرض التطبيق وخطوات عمل التطبيق وفي النهاية تحميل التطبيق للتدريب عليه . 


اما الدروس فتنقسم إلي قسمين 
ويحتوي : 
١‏ تحمیل برنامجچ 5۵12005 


SQL Server Management Studio Express 


http ://msdn.microsoft.com/en-us/express/bb410792.aspX 
http ://qo0.microsoft.com/fwlink/?Linkld=65110 
تحمیل‎ 5Q@1L2005_Service_Manager 


http ://moonfiles.com/in/upload/wh 18943946.zip 


۳- المدخل إلي2005_ا SQ‏ 

northwnd - PUB تحميل قاعدة نات‎ -٤ 

-٥‏ طريقة استيراد قواعد بيانات جاهزة. 

عمc)ںمۂیطایتحألا طريقة استیراد ملفات النسخ‎ ٦ 
۷٥W طريقة انشاء‎ -۷ 


Select Statment ga Jalaتll‎ -۸ 


أولاً : 
مفهوم SQL‏ 
يالاكود البرمجي اختصار 541 إلي ""لغه الأستعلام اlأınكiذ'' Language Structured Query‏ 


إن لغة ا5۵ هي بسيطة نسبياًء ولكنها فعالة للغايةء فالكثير من التعليمات البسيطة في هذه اللغة تخفي ورائها خصائص فعالة 
يمكن استخدامها للقيام بالعديد من العمليات المعقدة المعروفة في قواعد المعطيات . ٠ ٠‏ 

ثانيا : 

الفرق بين ا5 و sیمAcc‏ 

كثير منا يسأل الفرق بين قاعدة بيlنlت Microsoft Access gy SQL‏ . 

سوف نتناول بعض الفروقات بین اه8 و sیمA‏ 


Access : أولا‎ 


ایجابیاته : 

سهل الاستخدام 
رخيص الثمن 

توفر الدعم الفني . 
یدعم نماذج (وہ ۴٥۲‏ ) 
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٠: سلبيیات‎ 

الامان : ضعيف الامان بحيث يسهل سرقته واختراقه 

الحجم : يتحمل حتي ۲ جيجا 

عدد المستخدمين : ٠٠٠١‏ مما يسبب الضغط علي محرکات نظام ( عل )؟هS‏ هاا ) مما تسبب تلف للبيانات . 


Q1 : ثانيا‎ 

الامان : نظام الامان عإلي جدا 

الحجم : يتحمل حتي ١‏ تيرا بايت 

عدد المستخدمين : لأ يوجد عدد محدد 

يدعم خاصية الوظائف المعرفة مسبقا 51٥١٠١4 ۴إهءملںu res‏ و الترجرز ء۲٠‏ ووا۲۲ والتي نتطرق إليها في الدروس القادمة 


Microsoft Access j SQL jıب هذه بعض الفروق‎ 


أولأ : تحميل البرامج : 
SQL service manager‏ 
يمكنك تحميل البرنامج من الرابط التالي : 
لنظام التشغیلم× owsلWin‏ : 
http ://www.sqldbatips.com/samples/code/SQL2005SCM/SQL2005 Service Manager.zip‏ 
لنظام التشغيله†وا : 
http ://www.sqldbatips.com/samples/code/SQL2005SCM/SQL2005 Service Manager Vista.zi‏ 


بعد تحميل البرنامج يظهر البرنامج في شريط المهام 


e 


1 


Bl & ÊD 11:20 AM 
انقر نقرتين علي البرنامج فيظهر لك كما في الصورة‎ 


EG SQL Server Service Manager E 
DENYET: ج‎ 


TERWIGEZ: SAL SERYWEN ٠ 


Refresh services... 
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SQL Server Management Studio Expressاıilڏ‎ 
. تحمیل البرنامج‎ 


http ://www.microsoft.com/downloads/details.aspx?FamilyID=c243a5ae-4bd1-4e3d-94b8- 


a0f62bf7796&displaylanqg=en 
http ://msdn.microsoft.com/en-us/express/bb410792.aspX 


( Start --- programs---- microsoft sq|2005 ) لفتح البرنامج انقر علي‎ 


Lacation: C1 Prograrn Files Mic 


set Program Access and Defaults Server 901 Tonls Bini ysShelll 
Windows Catalog 
Windows Ipdate 
Phoneserye Internet Telephanë ® Mirrnenft OFFirEe م‎ 
lian Microsoft Office Gutlook, Lonnectûr | 


Frograrms 


Hl 3 ا‎ LISD FE 7 8 ٣ ê YE 2 1 0 E 


lin _anfiguratian Tools 


| 2 EE EE م‎ 3 Micrûsaft SAL SerYEr ۸ 


فا 
settings ۴‏ 4# 


2 Search ۴ 


SAL Serer Manaqermêit Studio Express 


2 Help and Support 


a RUN... 


Windows XP Professional 


Shut Down. .: MANTEL SED AZE4E7 44712... ۳‏ 0 
عند الدخول علي البرنامج تظهر لك النافذة الأتية : 


8 Connect to Server 


Microsoft 


SQL Server 2005 


SEF YE ype! | Database Enıgirız: ا‎ 


SEF YEF NHaArmE: 


: س‎ 
authentication: | windows authentication 


a TS 


HEerîermber:passmord 


حيث في خانة ممرآ مم5 يترك كما هو الأ اذا كان لديك اكثر من سيرفر يمكنك اختيار السيرفر المحدد من هذه الخانة 
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SQ فيه اسم السيرفر ( اسم الكمبيوتر ) ولمعرفة اسم السيرفر انقر نقرتين علي ايقونة معأ۷امء‎ بتكي5هrvمr‎ Name 
الموجودة في شريط المهام فيظهر البرنامج كما في الصورة‎ "anager 


SERWET: 


TEYICES:; 


Ww Auto-starl service when US starts 


فاسم السيرفر موجود في خانه م۷إم5 
اما الخانة الثالثة Auth) ءat 0٣‏ : فلھا خیارین 


أ : Windows Authentication‏ -دخول البرنامج دون الحاجة إلي اسم المستخدم والرقم السري 
ب : SQ Server Authentication‏ -دخول البرنام باسم المستخدم والرقم السري ويتم تحديده عند تنصيب البرنامج. 
زر : connec‏ الاتصال ب SQL‏ 


ء۶ « 


انتهي الدرس الثالث وسوف نبدأً في الدرس القادم باذن الله بالتطبيقات علي 5Q1-2005‏ 


الرس الرابع : شرح شاش Object Explorer‏ : 
يحتوي Mi‌r0s0 f 5Q1 Sever‏ علي شاشتین 


Object Explorer 1‏ - من الجهة إليسري 
تضم هذه الشاشة مزود مرتبي غلي سبيل المثال ( قواعد البيانات - جدأول - حقول - سرية النظام ( ... 
كما في الشكل 
ب : mary‏ صك - الجهة اليمني 
نلأحظ تحت السيرفر الخاص بالجهاز توجد مجموعات من الأجهزة المركزية حيث تنقسم هذه الأجهزة إلي اربعة اقسام نذكرها 
بشيئ من التفصيل 
Databases‏ : 


El lJ System Databases 
E lJ master 
ا‎ | model 


3 ازا‎ rmsdb 
# | J| tempdb 


# badar 
# ReportseryertEadar_SOL 
Report5eryertBadar_SQLTermpDE 
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ويحتوي جميع قواعد البيانات المخزنة في البرنامج ويحتوي كذلك ثلاث قواعد بيانات اساسية حيث لا يستطيع النظام العمل 
بدونها وهي : 


أ - Database Master‏ : وهي قاعدة البيانات التي يتم تخزين جميع قواعد البيانات فيها 
ب - اله مasطهاه5‏ : وهي فاعدة بيانات التي تحتوي الشكل الأول لقاعدة بيانات. 
ج - Database rempdb‏ : وهي قاعدة بيانات موقته . 


ثانیا : راهم : ويحتوي علي الكائنات المسئولة عن حماية قواعد البيانات وتوزيع الصلأحيات . وينقسم إلي ثلأثة اقسام . 
E SECUFIEY‏ ۳ 


Hl Logins 
El J Server Roles 


[O tredentials 


ا - "وها : يحتوي علي مستخدمي قاعدة البيانات وكلمات السر الخاصة بهم 1 
ب - هام8 إم۷إمS:‏ المستخدمين منقسمين إلي مجموعات . 


Managment ڇ‎ : Server Object ÛÛ 
وهي ادارة قواعد البيانات . وتحتوي علي‎ 
. النسخ الأحطياتية لقاعدة البيانات‎ : Ba) up - أ‎ 


ب - Linked Server‏ : ويحتوي علي المحرکات ( Provider‏ ) 
ج - Maintenance Plans‏ : يحتوي علي مخططات صيانة قواعد البيانات . 


انشاء قاعدة بيائات: - 


ئ هذا الدرس سوف ننشيئ قاعدة بيانات جديدة باصم Emp_iİnfo‏ 
ويحتوي علي الحو lتıllة ID - Name - Address - Gender - Country - Birthday‏ : 


لأنشاء قاعدة بيانات جديدة انقر بالزر الأيمن علي كموجطهاهدD‏ ثم اختر New Databases‏ 


FahasE= 


Pam GDatabase,,, 


Attach... 


E LO BE 


Restore Database} =. #vl' 


Restore Files and FilEgroUps... 
Reports ۴ 


Refresh 


في خانة : م2 مasطهاهط‏ نكتب اسم قاعدة البيانات ثم نضغط علي زر )0 
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0 


SrripE ” 2 Help 


[ 


Catabase name! نتب اسح فاعدة البيانات ,الماد رانشاتها‎ 
Oner: | Hef aulkz ed 


|_| Use Full-text indexing 


Database Files: 
Logical Hame | File Type | Filearoup Intial Size [MB]  Autogrowth 


Sannin anina nnn 


Data PRIMARY : By 1 MB, unrestricted growth 
_4 Lag Hot Applicable 1 BY 10U percent, unrestricted fû... 


RernaYê | 


اع | 


0 


كما نلأحظ تم اضافة قاعدة البيانات الجديدة 


EP Latabases 
E J S,stem Databases 
Database Snapshots 
ll badar 
FH || Report5erver$Badar_S4L 
EH [| ReportServer$Eadar_S5QLTerpDE 
Ernp_inifo 
El Database Diagrams 
3 Tablas 
# Yizs 


3 SYnoNYrs 

3 Prograrmrnabiliky 
3 Storage 

3 Security 
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انشاء جدول جدید 
لأنشاء جدول جديد لقاعدة البيانات الزر الأيمن علي وماطج۲ ثم اختروم اه7 New‏ 


Ernp_infa‏ ۲ ا 


Filter 


¬ Reports 
[+ 1 

O Security 

[I Server DbIETEE 


Refresh 


الأن نقوم بادراج الحقول المذكورة في الأعلي في خانةم Column Nan‏ 


_olumn Name Data Type 5اا دام‎ 

IÛ nchart10} 
JariE nchart 10} 
Adderss nchart10)} 
tender nchart 10} 
_ontry nchart10)} 
: ncharf 10} 


افك 


في خانة مم رآ هه نختار نوع البيان وطبعا في درسنا نختار النوع الأفتراضي 
اما انواع البيانات فسوف اشرحها بشيئ من التفصيل : 


النوع : "| يأخذ أرقام صحيحة سالب أو موجب وتکون بین - ۲٠٤۷۰٤۸۳۰٦٤۸‏ حتي ۲١٠٤۷۰٤۸۳۰٦٤۷‏ 
وياخذ حيز في القرص حجمه ٤٠‏ بايت. 


النوع : Bigint‏ مثل النوع النوع ۲| لکن حجمه أكبر ويقبل من — TTPFCPTVTOTTCAoeftNVoecAN‘sA‏ حتي 
775,7 ,9,223,372,030 
ویاخذ حیز ۸ بایت. 


النوع : ااك" يقبل 32,768 - حتي الرقم ۳۲۷٦۷‏ 
ه ‏ حجمه ۲ بایت . 


النوع : ۲"ارمآآ يقبل من ٠‏ حتي ۲٠١‏ - حجمه ۱ بایت. 


النوع : ها٥‏ يعني حرف ٠‏ وهو عبارة عن نوع يجعل حقل البيانات يتقبل عدد معين من الحروف من ١‏ إلي ۸٠٠١‏ حرف 
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النوع : وط يأخذ حروف ولكن حروف من النوع ملهءامل أي يمكن تخزين كل اللغات وليست اللغة الأنجليزية فقط وهو 
يتحمل من ۱ اف 0T‏ 


النوع : طج۷ يأخذ من ١‏ إلي ۸٠٠٠١‏ حرف - لكن حجمه بخلأف الأنواع السابقة غير ثابت حيث يكون حجمه حسب عدد 
الحروف التي فيها 

النوع : xة۳)إ۸2ءاج۷)‏ مثل جج۷ يأخذ ۸٠ ٠٠‏ حرف حيث يكون حجمه حسب عدد الحروف التي فيه. 

النوع : a2۲‏ نفس : مثل ع۷۲ لكن ياخد حروف ملهءاہل ولذلك هو يقبل ٤٠٠٠٠‏ حرف 

(Varchar(max ع۾ill‎ Jûa (Nvarchar(max : عوill‎ 


النوع : **** وهو يأخذ عدد حروف حتي ۲ جيجا بايت 
لكن من الخطأ فعل ذلك - فتخزين مذل هذا الحجم داخل خلية حقل واحد مع الاستخدام سيكون هناك بطئ في القراءة 


النوع : N****‏ مثل النوع **** لكن يخزن الحروف ك مod‌Unic‏ 


النوع : موه" | مثل النوع **** لكن نظام التخزين بيكون رهہا8 طبعاً نحن نستخدمه مع الصور وملفات الصوف وخلأفه من 
أمور المالتميديا 


هذه انواع البيانات 


الأن نضع المفتاح الأساسي للجدول وذلك بالزر الأيمن علي أول حقل )١(‏ ومن ثم اختيار صورة المفتاح 
Set Primary Key )‏ ( 


_olumn Name Data Type 5اا بدا‎ 
RE 
j Insert Lolurmn 
Delete Column 
Relationships... 
يا‎ 
IndexesfEEeYs,.. 
E1 


Fulltext Inde, ,, 
ML Indexes, ,, 


heck Lonstrainkts, 


menerate Zhange Script... 


لفتح الجدول نضغض بالزر الأيمن علي الجدول المراد فتحه ومن ثم ماطة7۲ ٣مم0‏ 


[= i Ernp_info 
IF [A Catabase Diagrams 
3 [I Tables 
Fl [I] SYsterm Tables 
HH Ez 
E A view Yaw Table... 
i Lg 5,0 Edit 
ll Lag Progî 1 
Hl a DEsign 


i Security acript Tablê a5 
TA “erer Chip 


HH A pen | OpenTable 
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Birthday 


| ender 

badar rilsrak arian 111380 
2 nabil FY 1 arian 1121385 
3 Fatma rıscak F arman 2151974 
4 salir armerak 1 aE 111382 
ِ 5ala ۴4i F aE AAII1275 
Ê 3ا52‎ sêEb F 2q4¥pkÈ AEE 
۳ khalid sahar 1 arian 351380 
3 باد‎ seEb F eqYpk E 
U U UL UL f UL U 


_OUNEFY 


النتيجة 


1 Adderss 


ame 


الأن عليكم تملية الخانات بالبيانات 


ولا : نضغط علي New Query‏ 


Fila Ed Yiew Tools Window Lommunity Help 


EEE REECE LEE EN 


فتظهر لنا نافذة الأستعلام من خانة قواعد البيانات نختار قاعدة البيانات التي تستخرج منها البيانات 


Pey UBF‏ غ 


3 Horthwind 
pubs 
ReportServer$Badar_SHL 

ReportSeryertBadar_SHLTermpDE‏ و 
i Ld Repl tempdb‏ 


IF | I Manan PEN 


الأن نكتب الأكود البرمجي في شاشة الأستعلام : 
أولاً القاعدة العامة :لاستخدام الأستعلام تنکون من کلمتین ) From ) J ( Select‏ ( 
فمتلا : اذا اردنا اظهار بيانات الجدول "٤٥‏ ا_م "ع نكتب الصيغة التالية 
. اسم الجدول ص٠۴‏ اسم أو اسماء الحقول اعمام؟Š‏ 


بعد كتابة الصيغة نضغط علي عاںم×ع 
فتكون الصيغه كالاتي ٥٤ہ‏ ا_م٣٤ ۴۲٠۳‏ * امام حيث ان * تدل علي جميع الحقول . 
فتكون الصورة كالاتي : 


\ € E_Mail: Mohamed.yoyo@gmail.com 


Prog: Mohamed Youssef 


5 


r 
| Î Results ÊÊ Messages | 
IO Name AÃAdderss Gender Lountyp Birthday 


badar  muscal Ml oman 111380‏ ا 

2 2 nmabl nwî M oman 1121985 

3 3 fatma  muscal,, F „ „man A EERE 

| 4 4 szalm  ameral نة‎ AMEE 

8 B1 salma rw 2 El ARM EHS 
E E salla  seeb F eAHp! TIES 
0 fF  khald sohar 1 aman 23713980 

| 0 û sala seeb F egypt MULL 


- 2اختيار حقول معينة من الجدول فئیكنcountryjù‏ - name - address‏ 
Select Name ,Adderss ,country From Emp_info‏ 
فتکون النتيجة کما فی الصورة 


س سوس وي ل mm‏ 


B...QLQuery2.sql™ summary | 


Belect Name „, AAdder3s ,cCountry From Emp 1ntlo 


% 


ا 
[Î Results | | Messages |‏ 


armê ûdderzs country 


1 i badar ; muscal oman 
2ا‎ rabil ri arnaãrı 
2 fatma  muscal oman y+ ا‎ 
4 salm ameral ae أت حك‎ ١ 
شي ج‎ 
5 salma HMI aE 
:ا‎ salla seeb egyp! 
1 Ehald sohar amar 
8 salya seeb eqHp! 


DISTINCT عبر‎ -۳ 

هذه الجملة المقصود بها اظهار البيانات بدون تكرار 

فمثلا في حقل رہ ںهC‏ توجد بعض الدول متكررة فاذا اردنا اظهار البيانات الموجودة في حقل ty‏ ںه٥‏ دون اظهار الدول 
المكررة نكتب الأكود البرمجي التالي : 


Select DISTINCT Country From Emp_info 


Prog: Mohamed Youssef ۱41 E_Mail: Mohamed.yoyo@gmail.com 


النتحة 


E 
able Databases PB 3 B-.-RLQueryZ2.sql™ Summary | 


3 FE 


Where ةرlبع‎ -‘ 


والمقصود به اذا اردنا اظهار كلمة معينة من حقل أو القاعدة 
مثال : نرید اظهار اسم إiاة»‏ من حقَل مصa×‏ 
فتكون لصيغه كالاتي : 

Select * From Emp_info 

Where Name = Khalid" 

**نلاأحظ اسم هاج بين علامتي تنصيص' هاج" ' 


meEleEZCTE * From Emp Info 
Where Name = 'Ehalid' 


5 
i] Results EE E | 


1 F7 khalid sohar M oman 3/5/1980 


5 Name A dHeras TET Birthday 


علما انه یمکننا استخدام المعاملات التالية اثناء استخدام عبارة Where‏ 


- تساوي 

>> ل تساوي 

< اکبر من 

> اصعر من 

<= اکڊبر من أو تساوي 
= اصغر من أو تساوي 

Between‏ شرط بين قيمتين 

Like‏ للبحث عن كلمة مشابهة 


Prog: Mohamed Youssef 


14۲ E_Mail: Mohamed.yoyo@gmail.com 


Order Byةرlبعe‎ -° 

والمقصود به الترتيب حسب حقل معين 

مثال : نرید عمل استعلام حسب ترتیب ول۸ 
الصيغة ‏ 

Select * from Emp_info 

order by Adderss 


فتكون النتيجة كالأتي : 


AELECTE * TEOM Emp: IEHEG 


HEEE py AAHEESS 


1 ا 


Î Fesults 


Ll Messages 


IL REE a lm TE EERdEÊÎ EEE Birthday 
1 4 zalim armeral 1 aE HERE 
ك‎ 1 badar j muscatl f M omar A RE 
3 3 fatma § muscatl | F carnan 21973 
4 2 ادم‎ [YI 1 oman AE Ela 
5 BÛ salma j ru F aE EA REH 
E 6E  saãlda j seeb F Earp RRR ES 
l7 3 salwa j zeeb F Egypt HLILL 
| 8 f khalid j sohaãr 1 omnãf 371380 
Or و‎ A۸ المعاملین‎ ٦ 
تستخدم للربط في شرطین أو اکثر‎ 
-معامل ك۸ : يقوم باستعراض النتائج في حال تحقق جميع الشروط‎ 
. ۔-معامل 0 : يفوم باستعراضص النتانج في حال تحقق شرط اي شرط من الشروط‎ 
: Aہd منال علي معامل‎ 
Select * From Emp_info 
Where Adderss ='muscat' 
and Country='oman' 
النتيجة‎ 
2 SL * From Emp info 
WHhEE HMOAMEESES =! mS AT 
AHA OURHEET=' orta" 
کا | ا 8 ا‎ | 
iJ Results li Messages | 
1 ID Hame Adderss Gender Lountrp Birthday 
1 1 i badar muscat M ûrmar 111380 
| 2 3 fatma muscal F omar 221973 
0 متال علي معامل‎ 
Select * From Emp_info 
Where Name ='salim' 
or Country='egYypt' 
النتيجة‎ 


Prog: Mohamed Youssef E E_Mail: Mohamed.yoyo@gmail.com 


EleEZTE * From Emp Info 
Where Name =' zal im' 
OE LOUNTEY='ETpET 


ا 


| Û Results EE Messages | 
| IO Hame Adderss Gender Lounty Birthday 


| 1 ٠ salm. ameral M FE 1113982 
س‎ [E šaldlã seeb F EqHp! IS EHS 
2 3 sala seeb F۴ aqypt MILL 


هذه بعض عبارات ومعامل ال ا5۵ 


أولاً : معامل ; Count‏ 
يعمل هذا المعامل لحساب عدد الحقول . 
متال : 


نرید ان نعرف عدد حقول جدول ہہ¡ _م٣٤‏ 
فتكت 
Select Count(*) From Emp_info‏ 


ثانيا : معامل |١‏ هو عبارة عن اظهار بيانات معينة من حقل معين 
مڎJl‏ : Emp_info Select * From‏ 
("Country IN(oman','uae where‏ 


Between : ÛÛ 

عبارة عن اظهار بيانات بين قيمتين 

هذه لن يتم شرحها ولكن ارجوا التجريب 
في حال وجود اي صعوبة ارجو ابلأغي . 
القاعدة 

[ Select 

اسم الحقل أو الحقول 

From 

اسم الجدول 

Where 

اسم الحقل 

Between 

١ قيمة‎ 

And 

قيمة ۲ 

ارجو التجريب وابرغي بالنتائج . 


التعامل مع اكثر من جدول وربط الجدأول 

في البداية نقوم بانشاء جدول جديد ( راجع الدروس السابقة ) 
واحفظه بالأسم الذي تريد ... 

الأن ادرج الحقول التالية في الجدول الجديد 

ID 

JobName 

ContractT ype 

selary 


Prog: Mohamed Youssef 4٤ E_Mail: Mohamed.yoyo@gmail.com 


بعد انشاء الجدول واضافة الحقول المطلوبة جاء دور الربط بين الجدولين 
اضغط بالزر الأيمن k۳ئي New DataBase Diagramsرتخا lkدzڊ DataBase Diagrams‏ 


Ermp_infa‏ اګ 
Database Diagram‏ 
Yiews‏ 3 
BEE Filter ۴‏ 7 
IF Progr armrnability‏ 
Storage‏ 3 
E LD Security Refresh‏ 
Fl I Northwind‏ 


Eeports ۴ 


الأن نضيف الجدأول المراد ربطها 


Add Table 


Tables 


Jabinfa 


الأن نقوم بسحب 1D‏ من جدول امع إلي | للجدول الجديد الذي انشاءته 
فيصبح الشكل 


Emp_info 


Jamie 


J1nbf 
Adderss ا‎ 


_antractT ype 
ender ۴ 


seller 
_OUNEFY ۶ 


Birthday 


بعدها نضغط علي زر حفظ ونحفظ العلأقة باسم معين 

بكذا تم عمل العلأقة بين الجدولين 

الدرس القادم باذن الله تعإلي سيكون في كيفية جلب قاعدة بيانات موجودة سابقا وطريقة عمل النسخة الأحتياطية ملا»ءهB‏ وطريقة 
تحمیل ال ملا Bac)‏ 


Prog: Mohamed Youssef f° E_Mail: Mohamed.yoyo@gmail.com 


فی هذا الدرس سوف نتناول كب كيفية ادراج قواعد بيانات جاهزة وكيفية عمل النسخ الأحتياطية Backup‏ 
للعلم امتداد ملفات 541 تكون بهينة 0۴ 


سوف اعرض برنامج فيه ملفات الأس كيو ال الأسlwسية‏ ) (Pub - North Wind‏ 
يمكنكم تحمليل البرنامج من الوصلة التالية : 


http ://rapidshare.com/files/120104132/SQL2000SampleDb.rar.html 


ثانيا : تنصيب البرنامج 


بعد فك الملف نقوم بتنصيب البرنامج 


Microsoft SQL Server 200Û Sample Database Scrip1s‏ ا 


Installing Microsolt SHL Seryer 200Û Sample 
Database serIpîs 


Microsoft SAL SEerYEr AUD Sample Database scripts |2 beligq Installed. 


Larcel | 


نجد الملفات في القرص سي ( ٥‏ ) 


NOR THWYTID 
SQL Serrer Database Transal,.. 
1,124 EB 


> ت لت ا E. instnwnd‏ 
ملفا الان کنو 


2 Microsoft SOL Server Query File 
لار‎ E8 


PLIBS_LS 
SQL Server Database Transal,.. 
Fé EB 


SS NORTHWRND . 
ا : ا‎ rye Galtabase Frimaty 1. 
1,23 EB 


I SL Server Database Prin 
ر2‎ 8 


Prog: Mohamed Youssef e E_Mail: Mohamed.yoyo@gmail.com 


ثالثاً : ادراج الملفات 


بعد ان نفتح برنامج 5۵1-2005 
-١‏ نضغط بالزر الأيمن عليعءهجطهام0 
۲- بعد ھا نخنتار attach‏ 


bject Explorer 


Restore Files and FileqroUps,.. 
EHeporks 


Refresh 


۳- بعدها تظهر شاشة لأضافة قواعد البيانات نختار ل١ك۸‏ 


Script ” Help‏ کک 


Catabases to attach: 


MDF File Locatinr Latabaze... | Alach A3 Liner Stalls MEzzaãqE 


Latabase details: 


>- الأن نختار ملف قاعدة البيانات الموجود في القرص الحلي ( ٥‏ ) 
ملاحظة . کن مثالنا اخترنا قاعدة بيlنlٽNorthwind‏ 


Prog: Mohamed Youssef 1۷ E_Mail: Mohamed.yoyo@gmail.com 


f Attach Databases 


select a page نے‎ 2 ۰ f srript r lj Help 


E General 
Latabases to attach: 


` MÛF File Locatiîr Database... Attach A3 Der talus Message 
: CASAL Server 2000... |... | Northwind Northwind MOEB3.., 


` File Type Lurrent File Path Message 
Conhertiah | FÊ porthnd,rmmndF SAL Serwer ZODOD Sar... eR 
٠ ۰ ا‎ narthwnd.,ldF SQL Server ZUUD Sa... ا‎ 


"Horthmind" database details: —f— 


SEerYEF: 


L_oûnnection: 
MOESI37S1AArninistrator 


wiew connection properktigs‏ پل 
Progress‏ 
Ready‏ 


HEYÊ 


aN ,لتخ‎ 


-٥‏ النتيجه 


Prog: Mohamed Youssef ۱۸ E_Mail: Mohamed.yoyo@gmail.com 


الدرس التاسع 


Object Explorer 


EEE 
3 8 SQL Server 3,0,1394 - MOES378 133A Aministratar) 
EE [Uatabases 
[J SYstem Databases 
E Database Snapshots 
[= 1 MNMorthmind 
FE A OGatabase Diagrams 
E A Tables 
E O System Tables 
HEH Î dbo, Categories 
EH ÛÎ dba. CustomerZustarmerDerna 
FH Û dbo, CustomerDernoaraphics 
EH Î dba. Lustomers 
FH ÛÎ dbo.Emplayees 
EH ÛÎ dbo.EmplayeeTerritories 
HEH ÛÎ dbo. order Details 
FH Û dbo. orders 
FE Î dbo.Pradurcts 
FH ÛÎ dba.Region 
EH Û dbo. Shippers 
FH ÛÎ dbo. Suppliers 
FEF Û dbo. Territories 
HA J ies 
Hl SYnONYrS 
E Cg Prograrmmabilikty 
E A Storage 
E A Security 


طريقة عمل نسخۂ احتیاطیۂ Bac) up‏ 


-١‏ نضغط بالزر الأيمن علي قاعدة البيانات المراد عمل نسخة لها 


Prog: Mohamed Youssef ٤۹ E_Mail: Mohamed.yoyo@gmail.com 


HA LD Gat * 
HA OD Tab 
EH LD vie 
3 اا‎ 
3# Prot) 
E E = 
E O sec Reports 


SeCUriKYy 
Server Obje Renarmê 
Replication Delete چ‎ 


Managerner 
Refresh denerakte Scripts... 


Properties 


- تظهر لنا شاشة تخبرنا مكان حفظ الملف 


F Back Up Database - Northwind 


1 
1 


Select a paqê | 4 Srript *” Help 


SUITE 
Database! 
Recovery model: 
Backup type: Full 
Backup component: 
(% Database 
Files and FlEAFOLUpS: 
Backup sek 
arme: Northwind-Full Database Backup 
Description: 
Backup sek will expire! 


ق اذا اردنا تر قان After:‏ ®( 
حفظ الملف نضفط = E‏ 
عئی 


Lonnetctian 


SEFYEF: Destination 
Back up to: 

_annectian; 

MESS 1331 Administrator 


a Yiew connection properties 


Progress 


۳- النتيجة 


O sx r” € 3 | Search I; Folders ERÊ 


Address (Oj CHAProgram Files\Microsoft SOL Server MSSAL.SMSSALBarckup 


Morthwind, bak.‏ ا 


Bûk File TT 
ملف البات اب مم عوج ۾‎ 


Other Places 


Prog: Mohamed Youssef 10۰ E_Mail: Mohamed.yoyo@gmail.com 


طريقة استرجاع النسخة الأحتياطية : 
في الدرس السابق تعلمنا كيفية عمل النسخة الأحتياطية لقاعدة بيانات معينة وفلنا ان الملف موجود في مسار معين 


O Back ” ا‎ 7 a earch 5 Folders EBÊ 


AddrEss m= Program Files\Microsoft SQL Server MSSAL.SISSQLIBackup 


1 Northwind, bak 


File and Folder Tasks : 


Other Places 


في هذا الدرس سوف نتناول كيفية استرجاع النسخة الأحتياطية : 


-١‏ الخطوة الأولي يمكنك استخدام احدي الطريقتين وكلأهما صحيح 


يمکن انشاء قاعدة بيانات جديدة وتسمستها باسم معين 
-النقر بالزر الايمن علي Database‏ و هذه الطريقه التي نسنخدمها في درسنا 


New Databaî 


Eattach:.. 


Restore Database... 


. Restore Files and FileqrfoUups.;; 
Reports 


Refresh 
تظهر لنا شاشة جلب قاعدة البيانات‎ - 
( نكتب اسم القاعدة البيانات ( كقاعدة بيانات جديدة‎ ٠ Dهاهطووم‎ : -في خانة‎ 
لجلب قاعدة البيانات من القرص المحلي‎ ۴٣٠۳ -في القسم الثاني من الشاشة نختار مام‎ 
-الأن نختار زر استعراض‎ 


۳- في هذه الشاسة نختار زرهيل۸ 


Prog: Mohamed Youssef 101 E_Mail: Mohamed.yoyo@gmail.com 


= Specify Backup 


Specify the backup media and its location For Your restore operation, 


Backup location: 


REROYE 


Lonkenks 


؛- الأن نقوم باختيار النسخة الأحتياطية من القرص أو المكان الذي تم تخزينه فيه . 


` Locate Backup File - MOESB378199 


Select Ehe File: 
ٍ MetaProducEs Inquiry 
MicrosoFE ActiYeSyNC 
Microsoft „analysis Ser YICES 
MicrosoFE LAPIZOM Z2,1.U0.2 
Microsoft Dewice Emulator 
microsoft FrontpagEëE 
MicrosoFE OFFICE 


“OE EEE EERE 


-H FTData 
£ OH Install 
1-H 3285 
E-T Lot 


ı1 mM FenldaFa | 


Selected path: [C:\Program Files MicrasaFE SL SerYErFIMSSAL .SIMSSAL | 
Files oF Eype: | Backup Files *, bakj* Ern} ا‎ | 


File narmë: 


ه- الخطوة الأخيرة نلأحظ وجود قاعدة البيانات نختار زر )0 


Prog: Mohamed Youssef o E_Mail: Mohamed.yoyo@gmail.com 


- × 


IT UTI 


srript ” [Ê‏ کک 


Destination For restore 


Select or type the name of a new or existing database For Your restore operation, 


To database: |moeforun ېه‎ 


Toa a point in kime: Mast recent possible | 1 


Source For frestorE 


Specify the source and location of backup seks to restore, 


(J Fram database! 


(@) From device: cr Program Files\Microsoft aL zerver(M5S5OL.SIMSSOL" 
| 


Select the backup sets to restore: 


E ۳ . {SQL Server 9.0.1399 [1 _ _ Jfedministrator) 


Databases 


a 


Zl | | moeforurn 
FF I Database Diagrams 
EI [I Tables 
E J SYstem Tables 
1 dbo. Zategories 
I dbo. Customer ZustormerDerno 
1 dbo. ZustomerDermographics 
I] dba. Customers 
E dbo.Ermployees 
I dbo.EmployeeTerritories 
I Abo. Order Details 
I dbo. orders 
E Hbo.Pradurcts 
Î dbo.Region 
Î dbo. Shippers 
Î dbo. Suppliers 
E dbo. Territories 


EEE EEE EE EE 


في الدرس القادم سوف نتطرق إلي كيفية التعامل مع سه۷ 


Prog: Mohamed Youssef or E_Mail: Mohamed.yoyo@gmail.com 


الدرس العاشر وسwعز۷ا:‏ 


مشاهد البيانات أو i5‏ تشبه کثیراً استعلامات الأكسسر Query‏ ( 
وهي تستخدم للعرض من عدة جدأول كما نلأحظ في درسنا 


الفائدة من المشاهد 
طبعاً الفائدة الكبيرة منه التحكم بصلأحيات الوصول) لتحد 


يد الحقول المسموح برؤيتها مثلا لهذا المستخدم أو ذاك(.. 


في درسنا سوف ننشئ مشاهد ( سه۷ ) ونضيف فيه البيانات الأتية 


*انشاء ۷٥W‏ جدید 
نضغط بالزر الأيمن علي و سه۷ كما في الشكل 


EY iE, ,, 


۴ 


۴ 


ثم نختار wمNewVi‏ 
في الشكل التالي يظهر لنا مربع نضيف الجدأول المناسبة 


Customers‏ : جدول ا 

CompanyName -- ContactName‏ : الحقول 
Orders‏ : جدول؟ 

OrderDate‏ : الحقول 

]Order Details]‏ : جدول" 

UnitPrice --- Quantity --- Discount‏ : الحقول 


EES 
3 | Northwind 
FF O Catabase Diagrams 
E LN Tables 


Filter 


> RHeports 
1 J Security 

J] ig Server ob 
1 J Feplicatio 


Refresh 


EDI 


Tables | Yiewys | Functions | 
LalEqOrİES 
_USEomer_ustaomerDEermn 
_ustomerDernographics 
_USEOMErS 
Ernployees 
ErmployeeTerritories 
irder Details 
irJEers 
Products 
Region 
Shippers 
Sppliers 
Territories 


ESER 


E_Mail: Mohamed.yoyo@gmail.com 


Prog: Mohamed Youssef 


بعد اضافة الجدأول التي نريد استخراج البيانات منها نختار الحقول المناسبة 
للعلم ( نلأحظ انه بمجر ما نضيف الجدأول العلأقات تظهر بين الجدأول وبالامكان ايضا عمل علأقات بين الجدأول ر 


BE Orders EH Order Details Ei 
| | * اا‎ olun الق *| _ إ5‎ column 
|_| OrderıDp 
|_| CustomerID 
ا‎ ESE 
| wirderDate 
__ |REquiredDatE 
| |ShippadOate 
|_|ShipYia 


|_ Freight 


في هذا الشكل نلأحظ ظهور الجدأول والحقول 


olur E Table wiJEpUE | Sort T¥pE 
F CompanyName Customers 
ContactName Customers 
rderDate rders 
LInitPricE [Order Det,,, 
Quantity [Drder Det... 
Discount [Order Det,,, 
0 


وفي الشكل التالي يبين الأكود البرمجي الخاص بالمشاهد وطريقة ربطه 


SELEZLT Abo: tustomers,. ZompanyMarme, dbo, Lustorners,.LontactName, dbo, Orders, OrderDatëe, dbo, [Order Details]. 
dba, [Order Details]. Discount 

FEM dbo, Orders IMMER. IDI 
dba, [Order Details] OM dbo, Grders, DrderID = dbo, [Order Details |]. DrderID INNER. I2I 
dba, Lustomers OM dbo, Orders, ZustomerID = dba, Lustormers, CustomerID 


بعد الأنتهاء من اضافة الجدأول والحقول نضغط علي زر ۴5 أو علي 


_olurmn Table wutput | Sort Type Sart Order Filter 
lInikPrice irder Det,,, 


Prog: Mohamed Youssef oo E_Mail: Mohamed.yoyo@gmail.com 


| ا‎ | CompanyName contartmlarme CrderDakte LUnitPrice | Cuantity Discount 
ine ek alcûnlê L,,, Paul Henriot TEE 1A:DO:.,, 14,0000 172 1 
| ins êk alcool ZL... Paul Henrik A4146 1AOD:.,, 3,8000 11 1 
|Yins ek alconls 2... Paul Henrint FIA 12:0D:... 34.8000 5 1 
Toms spezialitãten Karin Josephs ISI 12:0U:.., 15,6000 3 1 
[Toms apezialitaten Karin Josephs FISTIAAETAOD:... 424000 4 1 
| Hanari Lartnes Mario Portes BIA TAO, F7. 7OUU 11 1 
|Hanari _ãfHES Mario Pontes BT1 TAOU:..,. 42,4000 ك‎ IAS 
(Hanari _aArNHES Mario Pontes 7IBTIAA6 1A:OD:... 16,8000 15 1.15 
Î victuaillês en stock Mary Saveley FBI 12:0D:.,. 16,8000 6 0.05 


سس س س 


ml am سس ر‎ 


1 ر 


ثانيا : خيارات الجدأول 
يمكننا اضافة الخيارات من الحقول مباشرة أو من خلال الشفرة كما فعلنا في الدروس السابقَة) ... Count - where‏ ( 
خاصية Sort Type‏ 

0r Type 


Ascending 


Descending 
LInsorted 


في حال نرید اظهار بیان معین من حقل معین فنختار خاصية,٥]!¡۴‏ 


2 _olurmn Table wıtput Sort Type Sart Order Filter 
| LInitPricë Lrder Det,,, 
ulantiky [Order Det,., 
| Discourik [Order Det... 
1 
| L1 
النتيجة‎ 
| ٤ LampanyName آ7‎ cartarttame DrderDate Unitprice quantity | Discount ۰ 
* [Tome Spezialtêten Karin Josephs. 7/51996 12:00... 424000 | 40 00 j0 
| ÊÊ dêlices. Pascale Lartrahn FIA 1496 12:DO!.., 64.8000 4 1,05 
/ Suprêmes dêlicešs Pascale Lartrain FAIA TADO:.., 27,2000 4 1 
/ Harari LANES Mario Portes HIDA 12:0... 16,0000 41 1 
| (Rattlesnake Lanı,, Paula Wilson SA 1336 12:00... 10,0000 40 1 
| QUICK-Stap Horst Kloss 201996 12:0... 14,7000 0.2 
| QunCKStop Horst Kloss SAIFIAAE 12D... 33,4000 1 
| lRirarda Adarir= 1ariaka | imiêira aH AAÊ 12n 12 anîîî i 1F 


mm - Fa E HM Ma Im 1 
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ADO.Net 2 Programming gs Jail ر‎ 


NET ..‏ .0 هي التقنية التي تسمح لنا بالتعامل مع قواعد البيانات من داخل بيئة ال . NET‏ حیث تقوم هذه التقنية علي مبدأ 
Oriented Programming Object‏ , وهي عبارة عن مجموعة من ال ءءءءهاء و التي تمكننا من الوصول إلي البيانات 
من خلال اللغات التي تدعهما N٤۲‏ . ضمن فضائي الأسماء aأaل.”mءsyst‏ ي system.xml‏ 


حیث تمتاز ال 0.٤۲‏ بميزة التعامل مع مصدر البيانات في وضعين: الأول وضع متصل 4ء†ءم",هء و الوضع الأخر و 
ضع مiففصJ Disconnected‏ . 


و لقد نشأت ال 0.٤۲‏ من تقنية سابقة تدعي ۸50 وهي اختصار للكلمات †ءمزط0 واج ×مtivءA‏ و كانت الل A50‏ 
تمثل مجموعة من ال ومووهاع المستخدمة في لعات البرمجة السابقة مثل اuaءاا‏ 6 ءiوهط‏ للوصول إلي کک في قواعد 
البیانات › و ۸00.٤۲‏ تقوم بنفس الأغراض التي كانت تقوم بها ال ۸500 و لكن بأسلوب محدث وأسهل . ' 


حدر يانات 


pآ‎ -NET Provider JFXXDO.NET 


‘Data Providers ٽIilڊll‎ تIدوزم‎ 


تسمح لك ۸50.۸٤‏ بالأتصال مع مصادر البيانات ( برامج إدارة قواعد البيانات علي اختلافها: أوراكل› MS ؛SQا Sم ve‏ 
5ئ وغيرها) ولتحقيق هذا التعميم يوجد مجموعة واحدة من الءمءءهاع في !ADO.NET‏ 

وبما أن مصادر البيانات المختلفة تعمل ببروتوكولأت مختلفة» لذلك فنحن نحتاج إلي طريقة صحيحة للتعامل مع كل مصدر 
بالبروتوكول الذي يناسبه» بعض مصادر البيانات القديمة تستخدم امهاهام 058٥‏ وبعض الحديث منها يستخدم ما0 
.protocol‏ 

۸D0.N7‏ تقدم طريقة عامة نسبية للتعامل مع مصادر البيانات كل علي حده کی مكتبة خاصة»› هذه المكتبات تسمي واج 


Pi‏ وغالباً یکون اسمها د ADO.NET‏ علي اسماء البروتوكولأت التي تستعملها مصادر البيانات» الجدول التالي 
يوضح بعض مزودات البيانات المعرفة ى AP| Aãڊlwgy ADO.NET‏ التي ستعملها ونوع مصدر البيانات الذي تتعامل معه“ 


Table 1. ADO.NET Data Providers are class libraries that allow a common 
way to interact with specific data sources or protocols. The library APIs 
have prefixes that indicate which provider they support. 


Provider Name API Prefix Data Source Description 


Data Sources with an ODBC 
BE Data interface. Normally older data 
Provider 
bases. 


Data Sources that expose an 
OleDb Data OleDb OleDb interface, i.e. Access or 
Provider Eyeêl 


Oracle Data 
SQL Data For interacting with Microsoft 
Provider SQL Server. 
Generic access to many data 
Bdp bases such as Interbase, SQL 
Server, IBM DB2, and Oracle. 
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كمثال يوضح استخدام سابقة |۸۴: عند الأتصال بقواعد البيانات أحد أول الكائنات وأءمزط0 التي ستستخدمها هو 
أecزob Connection‏ - كما سيأتي شرحه لأحقاً- والذي سيسمح لك ببدء اتصال مع أحد مصادر البيانات» لو كنا سنستخدم 
OleDb Data Provider‏ لکي نتصل مع مصدر البيانات (قاعدة بیانات آكسس أو ملف أكسل متلا) فاننا ببساطة سنضيف 
سابقة إ۸ الخاصة ب إملiاPro Data‏ ٥ا0‏ وهي من الجدول السابق ط٥ءا‏ إلي اسم الكائن ليصبح 
.OleDbConnection‏ 

وهكذاء کائن الأتصال يبدأ ب ءطل٥‏ لیصبح 0dbcCon e0‏ عند استخدام مزود بیانات ھ†ھd source 0d٥‏ › وکائن 
الأتصال یبدا ب اك لیصبح ۸هiام""ه|اوS‏ عند استخدام مزود بیانات .data طa5٥ 5Q1 S66‏ 


وحيث أننا سنستخدم قاعدة بيانات آكسس في دروسنا و مزود البيانات لهذا النوع هو ط٥ء|ا0‏ فإان سابقة كل كائن سننشئه 
ستكون ط٥01‏ وبامكانك تغييرها إذا كنت تتعامل مع مزود بيانات لقاعدة بيانات أخري كما يوضح الجدول السابق! 


فئات مكتبة ۸50.61 


مكونات الوضع ilئinفصJ Disconnection‏ 


Uirm Rec A45 ÛUalaRow 
Oim FReci j As UaltaRow 


Command 
Builder E 


Dim cmAdb As Nei Uim ad As Mey Bim HBS AS New BDataSet 
le DBroOmMmmandBuilder le DbOataAdapter 


COim cn A5 New OlelDibtronnection ¥ 4 


_ Cim Tel A5 New 
OataTable 


Gim cmd Ããs Hew Ole Db ommand 


LataSet 
EME TTT 
يداحله الكاتن‎ 


earner [== 


Woussey‏ ر 
مكونات الوضع اأئمتصJq Connection‏ 


Data Base > 
connection ` Oim cen A5 Mew Ole Dbtronnectiaon 
Lim cmd ã5 New le DObBtrommand 
Command 


rOMmaAnd ‌ 


Oirm cCmaidb A5 Reavy 


Tle GbCeommandBEuildler Lim ÛR ã5 Hew UataReader 


AMlofamed Woussey 
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ADO.NET Objects : 


Connection. 
Command. 


)وضع متفصJ( DataReader.‏ 
)وضع مiففصJز( DataAdapter.‏ 
(وضع منفصل) DataSet.‏ 


eh E TE 


والرسم التالي يوضح مفهوم استخدام كل كائن ونطاقه'. 


CIient 


Sslsact Sommandl 
Insert LUommand 
Us lte Command 2 SERVER 


Co titra Trl . ا‎ 


ئ 1G‏ 
e‏ کک سے نے کے 
قى 


1ZSpTtAOIA qf 


1ı23depye eqa 


B-DataReadler "connect" 


DataAdapter تlنlيıنl‎ Jُوحم‎ 


تتف عة ا لبيانات 
DataSel‏ 


Na J‏ إا س 
قاعدة الساتات 


Database 


System Data.OleDb 
System. Data. SqiClent 


- پو اسطة : k-s-b‏ ¢ الموسوعة العربية للكمبيوتر والإنترنت › التعامل مع قواعد البيانات من السي الشارب ٣#‏ > بتاریخ ۷ أكتوبر ٠۰‏ 

http://www.c4arab.com/showasection.php?Issid=108 , Viewed 12/10/2008‏ 
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سيناريو الوضع المنفصل' 


عند التعامل مع 400.٤1‏ فى الوضع المنفصل عل10 4ع†ءعصصەعء1(, فالسيناريو يوضحه 
لك (شكل 3-18) والذي يكون كالتالي: عندما تفتح اتصالا مع مصدر؛ اسند مرجع كائن الأاتصال 
Connection‏ إلى گائن إع†dap Dat A‏ و هو يمثل همز ة الو صل بين الكائن ع5ة0a1‏ ومصدر 
البيانات؛ بعد ذلك ارسل البيانات المراد تعديلها إلى كائن (115٥‏ وبذلك يمكنك انهاء علاقنك مع 
مصدر البيانات و اغلاق الاتصال المنشےء بالگائن 10۸1ع .C.0n1‏ 


ل ا رر و 


حصضدر البيانات 
GLGataSet Ea.‏ 
ت ST DLataAdapter‏ 


سيناريو أستخدام كائن المحول مامه ل۸هاه50 مع مصدر البيانات و كائن م5هاهD‏ 


ربط برنامج بال 2003 ۷8.۸61 مع قاعدة بيانات تم إنشاؤها علي |ئ— Microsoft Access‏ ' 


في البداية أود ذكر أن قاعدة البيانات التي قمت بانشاءها بسيطة جدا قمت بتسميتها ط_ء_» و تحتوي علي جدول واحد فقط 
يسمي. patie n‏ 


: view >> server explorer الأن من القائم‎ 


wiy | Project Build Debug Data 


=| Lode FF 
-ë| Designer Shift+FF7 
E pen 

pen With... 


salutian Explorer w_krl+Alt+L 


2 
ن‎ 
4 Class View ctrl+shift+C 


Server Explorer Ltrl+Alt+5 


ResolrCe Yi wtrl+Shift+E‏ ا 


أ - م / تركي العسيرى : برمجة أطار عمل †مN.‏ باستخدام PDF File › Visual Basic.Net‏ » الطبعة الاولي ۲۰۰۴۳ » ص۳۸٦‏ 
2 - بواسطة : k-s-b‏ ¢ الموسوعة العربية للكمبيوتر والإنترنت « التعامل مع قواعد البيانات من السي الشارب ٣#‏ > بتاریخ ۷ أكتوبر ٠۰‏ 
http://www.c4arab.com/showasection.php?I1ssid=108 , Viewed 12/10/2008‏ 
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سيظهر لك ما يلي بجانب صندوق الأدوات: 


| Ê Data Link Properties 


Provider Lonnector | Advanced | ات‎ | 


Specify the following to connect fo Access daka: 


1. Select or enter a database nare: 


2. Enter Information to loq or to the databa3E: 


LIzer name: ÃAûmir 


IW Blank password FT Allow saving pazsm#rd 


قاعدة البيانات التج تريد 
زبطها بالبرناصج.. 
تح OK‏ .... 


Jest Connector ) 
UF. LafcEl Help 


سيظهر لك في نافذة ال ۲مإهام×م مم5 ما يلي. 


Serwer Explorer 


4 | 8 
f Data ı_annerctions 


=1. Bk ACCE55,D data basées-b,mdbtdmin 
Tables 
: 
+ طط‎ WIENS 
+ ا‎ stored Procedures 
+ Ei SEFYEFS 


1240 K3 AAAS 1 


2 


+ 3 A_LES5.D data base k-5-b. mdb, ãdmin 


ا 


1310| AANA 7 


| Server Explarer 


Add Zonneckion,., 


Lreate New SAL Server Database... 


إ 


Ed Data Link Properties 


Frawider Connection | Advanced | ات‎ 


Select fhe data you want fo cofneet toa: 


ULE DB Prowiderlz] 
MedıaLataloglBE ULE DE Prowider 
MediaL-ataloaMergedDBE ULE DB Pro¥ider 
MedialatalagsbDB DLE DB Prayider 
Microsoft Jet 3.51 DLE DB Prosider 

[Microsoft Jet 4.1 OLE DB Prowlder ooo 
Microsoft ULE DE Provider For Data Mining S5erYIicez 
Microsoft DLE DE Provider for lnde=lng Service 
Microsoft DLE DE Provider for Internet Publishing 
Microsoft ILE DE Prowider far ODBC Drivers 
Microsoft ILE DE Provider for ULF Seryices B.U 
Microsoft ILE DE Provider for Uracle 
Microsoft ILE DE Provider for Uutlook Search 
Microsoft ILE DE Provider far SAL Server 
Microsoft DLE DB Simple ProYlder 
MS UataShape 
LE OB Provider for Microsoft Directoy SerYIces 
YWSEE Yersloning Enlistment Manager Prop Data 5 ource 


OF. | LafcEl ) Help | 


wer Explorer 


4 ® 8 


Lata L_onnectiaons‏ ا 


+ El SEFYEFS 


12403 AANA 2 


2 


لأحظ بالأعلي أنه تم إدراج قاعدة البيانات التي سنقوم بربطها مع البرنامج , فقط قم الأن بسحب الجدول المراد من هنا و 
إسقاطه علي ال( form‏ فی هذه الحالة اسم الجدول "Patient'"),‏ وبعد ذلك سیظهر لك الكائنين التاليين أسفل اأ.form‏ 


EL aleDbDataAdapter 1 


۱11 E_Mail: Mohamed.yoyo@gmail.com 


aleDbLoannectioni1‏ ا 
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و لأنشاء الكائن: DataSet‏ 


اضخط شنا بالزر الأيصن 
نح قح باجيار 


E nnn ليننك لديك‎ eee lele lele 
E iE nde 1 5 1 E 
: 3 aleDbZonnectionl uleDbDataAdapterl } dataset11 4 


wonfigUre El Adapter. ES 


meneralte Datasel,,, 


PFreviey Daba,,, 


انتهينا الأن من ربط ال ]٠۲۳‏ مع قاعدة البيانات. 
نريد الأن أن نستعرض محتويات أحد جدأول قاعدة البيانات التي قمنا بربطها مع البرنامج. 


ولعمل ذلك سوف نستخدم الأداة 40 لعرض الجدول بها , لذلك قم بسحب هذه الأداة الأن من صندوق الأدوات و 
إسقاطها علي lأ,Form‏ 


GÎ DataGrid | | 


| EE Forml 


و في حالتنا هذه نريد أن يتم تحميل الجدول علي ال ها6 هاه بمجرد تشغيل البرنامج لذلك سوف نقوم بكتابة الأوامر داخل 
lڏ......Constructor‏ 


الأن انتقل إلي نافذة ال مههء و اكتب الأوامر التالية.: 
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الىرنامج: 


في البداية قمنا بتعبئة ال مهه بالجدول "1" ء اج٥"‏ الموجود في قاعدة البيانات التي قمنا بربطها مع البرنامج . و ذلك 
باستخدام الدالة ١١ز۴‏ مع الكلأس ۲ءامهل212۸Aط٥ءاه‏ بحيث أنها سوف تستقبل في البارمتر الأول اسم ال ا56هاهص المراد 
تعبئتهاء و البارمتر التاني هو اسم الجدول. 


و لكي نعرض الجدول في الأداة ها 6هاه قمنا في السطر الذي يليه بربط الأداة Qا6هاه0‏ بال 56هه0 وذلك باستخدام 
الدالة ( )يلا8 هاه12م5 : بحيث أن هذه الدالة تستقبل بارمترين الأول و هو اسم ال مهه و الثاني هو اسم الجدول 
الموجود بها. أما إذا كان لديك استفسار فی عبارة try , catch‏ فعليك مراجعة الدرس " السيطرة علي الأخطاء Exception‏ 
handling ""' ...‏ 


و نتيجة تنفيذ البرنامج كالتالي: 


HÊ Form1 E EK 


| First arme | Last arme | PatientlD 
sama Erad 1 
Mohammed Marısoor 

khalid Ahmed 

Maser ûrırnar 


لقد تمكنت الأن من ربط برنامجك بقاعدة البيانات و عرض محتويات الجدول لديك بنجاح. 
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Reports juرlقill‎ 


طريقة إضافة تقرير للمشروع .. 


من القسم ۲٥إهام×ع‏ «٥اںاه‏ أنقر علي اسم المشروع بالزر الأيمن تم تابه الصور التالية : 


E_Mail: Mohamed.yoyo@gmail.com 


aol tian E#plorek HK 


AEE 


| El Learn ADO.NET DataRelz 
. | و أنغر عليه بالزر امن‎ 


| Forma,¥b 
rptZrystalReport 1 ,rpt 


2) Build 
Rebuild 2 
lean 
Publish... 


1II YEB HEFEFENCE,,. 
e Yiewy lass Diagram 


Debug ۴ 


ا 


Rename 


i Properties 


PHewy Folder 


indos Forrn,.. 


LISE Lontrol,,, 


w_oarmponent... 


Module,,., 


Lla55,., 


1٦ ٤ 
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Templates: بم‎ 
__ sual Studio installed templates 


1 E 
> = = E ا‎ 
کا ا‎ _——-_ 


Windows For Dialog Explorer Forrn MODI Parent About Box Lagin Form Splash Screen las 


ا 
أ 


Farr 
A MM BH @ & 
"Module Interface Laomponent ZOM lass Dataset 
55ا‎ 
3 ã FH & 
lser Zantrol Inherited Farr Inherited ser Lustor Web Zustormn Resources File Settings File ode Filë 


antral antral antral 


wa x aa a a ae a a a e a a a 1 a o a a a 1 a e a E a a e a a a E i a E E E r 1 


MamE: 


اگتبا ای اسع للتقرير CrystalReport1 tpt‏ | 


CT YEtal HREPOTTS Galley 
wreate a New Crystal Report Document 


(e) Using the Report 0O 


(J Az ã Blank Report 


Lhoasê ãnı Expert 


E Standard 
Ê cro55-Tab 
Mail Label 


wuides he creation of ã typical report, 
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Data 
~hooase the data You want to report on, 


E EOF TSTEEEES 
ا حدد.قاعدة البیانات الت تستخدمهارفي‎ Ê 

٣ [Favorites aaa aki 

H: AHistory 

H-AEreate Maw _onneckian 


"J Standard He porî Lreation Wizard 


Grouping 
Optional} Broup the information on the report, 


| Available Fields: Group By: 
aê Report Fields 


TheBank, AskNJurm ber‏ ا 
a‏ 


8 data, Ask 
۰ “ES data, AnsHEr 
2E) TheBanık 


AskNurmber‏ کک 
H--BE] data‏ 


Erase Data... || Find Fields. 
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| J Standard HepOIÎ Lreation Wizar û 


Record Selection 
optional Select a subset of information to displaY¥. 


` Awailable Fields: Filter Fields: 
2-H Report Fields 
: .-E& TheBank. ID 


“Em TheBank, AaskNurmber 


eı data, ask 
ٍ ıı dala, Ans5HEr 
SEE TheBank 


ٍ a AslNJumber 
H--EE] data 


Report Style 
Select ã Formatting style For the report, 


ûYailable Styles PreYjaıwy 


standard 
Leading Break. 
Trailing Break 


Oroap Tablë 

Executive, Leading Break 
Executiwe, Trailing Break 
ahadirnga 

REedfBluae Border 
MaroonfTeal Bo: 


. وه 4ه = n n = na al‏ س 
ا ا ا 
ا ا ا 
ا a a‏ ف سے ا 


: ¥ 3 کر‎ If 
3 1 : > الالهي‎ 
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¥ bectonl [Report Header | 
9 1 ا ا 0 1 ا‎ N 0 0 ا 0 1 ا 0 1 ا‎ 1 E 0 0 1 N 1 0 ا ر ا 0 1 ا 1 ا ا 1 ا‎ 1 E ر 1 ا 1 0 2 ا‎ 2 1 O 0 ر ا ا 1 ا‎ 
O E E O O E E E O E E E E E E E E E E 
¥ heclond [Fage Header | 


E METTA ORO OO 


1 2 قا اق ا وا و ا اوا ها و ا و ا ةا اة ا و ا ةا وا وا وا وا اة ا و اة ا وة د وة ا وا وا و ا وة ا اة ا و ا و ا اة د ةا و ا وا و ا ا ق ا ق ا و ا اة ا و ا و ا او ا ب 


¥ beclond [Detalls | 


jr ASlumber 


LLL LLL LLL LLL" 


ا 


اضف في التقرير بالذات في ۸2٥ءم5‏ مربع نص وليكن اسمه 11×ه] كعنوان للتقرير . 


CrystalReport1.rpt Î InformationBankDataSet.xsd* 1 Formi1 Yb [Design]*  SEart Page ا‎ 


2 جر َ ا 7 س‎ ١ 
r ت‎ 2 HF TE1 E E. 100E ا‎ BusinessObjects’ 


AUOFTNTAAT 


% 
TREE 
23,097 
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اشر هنا لمعاينة التقرير 


Main Report Prawjaiyy “ ۳ 


Em 


Main Report 


ثم من القسم ۲٥إoام×٤‏ ہ٥آاں‌ام5‏ أنقر علي اسم المشروع بالزر الأیمن تم اختر >> Add‏ ثم >> m٥tاسم.‏ تم اختر >> 
Windows Form‏ تم اعطیه اي اسم ولیکون ۴٥۲۳٣2‏ . 
بعد ذلك اذهب إلي ۴٥٣2‏ واضف إلية أداö5 CrystalReportViewer1‏ . 


بعد ذلك اذهب إلي ۴٠۲2‏ في وضع كتابة الأكود البرمجي وأكتب ما يلزم من الأكود البرمجي التالي : 


Prog: Mohamed Youssef ۱۹۸ E_Mail: Mohamed.yoyo@gmail.com 


Imports System.Data 
Imports System.Data.OleDb 
Public Class Form2 

Friend strConn2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Application.StartupPath & 
"Information Bank.mdb;User Ild=admin;Password=;" 

Friend strSQL2 As Siring = "SELECT TheBank.id, TheBank.AskNumber, data.ask, data.answer 
FROM TheBank INNER JOIN data ON TheBank.ID = data.IlD ORDER BY TheBank.AskNumber;" 
"SELECT TheBank.id, TheBank.AskNumber, data.ask, data.answer FROM TheBank INNER JOIN data 
ON TheBank.ID = data.ID WHERE (((TheBank.!ID)=18)) ORDER BY TheBank.AskNumber;" "SELECT 
TheBank.id, TheBank.AskNumber, data.ask, data.answer FROM TheBank INNER JOIN data ON 
TheBank.ID = data.ID ORDER BY TheBank.AskNumber;" 

Friend cn2 As New OleDbConnection(strConn2) 

Friend daTheBankAndData2 As New OleDbDataAdapter(strSQL2, cn2) 

Friend MyDS2 As New DataSet 

Private Sub Form2 Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load 

Try 

cn2.Open() 

daTheBankAndData2.FilI(MyDS2, "TheBankAndData"") 

cn2.Close() 

Dim rpt As New rptCrystalReport1 

افقي أو عمودي تحديد مسار التقرير و التحكم في وضع التقرير اما" 

rpt.Load(Application.StartupPath & '"\" & "rptCrystalReport1.rpt"') 

rpt.SetDataSource(MyDS2.Tables("'TheBankAndData"")) 

عمودي في وضع التقرير اما افقي أو التحكم ' 

rpt.PrintOptions.PaperOrientation = 
CrystalDecisions.Shared.PaperOrientation.DefaultPaperOrientation 

2 هذا الأكود البرمجي يقوم بالكتابه في مربع النص الموجود تاخل التقرير في الموقع رقم ' 

CType(rpit.Section2.ReportObjects('Text1"), 
CrystalDecisions.CrystalReports.Engine.TextObjec).1 ext = "والأجوبة المخزنه في البرنامج تقرير يستعرض الأسئله""‎ 

معينه من البيانات كي تظهر في التقرير استعمال الفورملا لتحديد مجموعة ' 

للتقرير تعيين شرط تحديد البيانات' 

السجلات يمكنك الأستغناء عن الفورملا إذا اردت ظهور جميع ' 

rpt.RecordSelectionFormula = (' {TheBank.AskNumber} = " & Form1.txtnumber.Text & '""") 

وعرضه تهينةمستعرض التقرير ' 

CrystalReportViewer1.ReportSource = rpt 

CrystalReportViewer1.DisplayGroupTree = False 

CrystalReportViewer1.ShowGroupTreeButton = False 

CrystalReportViewer1.RightToLeft = Windows.Forms.RightToLeft.Yes 

التقرير في حجم الصفحه فتسهل عملية قراءته وهذا السطر الأخير لكي يظهر ' 
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وملاحظة الفرق يمكنك تغيير القيمة ' 

شيئا حأول ولن تخسر' 
CrystalReportViewer1.Zoom(1)‏ 
CrystalReportViewer1.Refresh( )‏ 
CrystalReportViewer1.Show( )‏ 


Catch ex As Exception 
MessageBox.Show(ex.Message, " Show CrystalReport ... '', MessageBoxButtons.OK, _ 


MessageBoxlIcon.Information, MessageBoxDefaultButton.Button1, _ 
MessageBoxOptions.RtlReading) 


End Try 
End Sub 


End Class 


E_Mail: Mohamed.yoyo@gmail.com 
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الجزء السادس : امساعدة م16 


الحصول علي المساعده 


يتضمن الفيجوال بيسك ستيديو مركز مراجع الألكترونية يدعي 2005 Microsoft Visual Basic Sudio‏ 
Documentation‏ ( وثائق مایکروسوفت فيجوال ستديو )٠٠٠٠١‏ يمكنك استعماله لتتعلم أكثر عن بيئة تطوير 
الفيجوال ستيدیو > لغة البرمجة فیجوال بيسك ¢ الموارد شي المكتبة Net Framework‏ . « المجتمعات علي الخط 
المتخصصة في الفيجوال بيسك و الفيجوال ستيديو > الأدوات المتبقية في الطقم فيجوال ستيديو . خصص وقتاً 
لأستكشاف موارد المساعدة تلك الأن قبل أن تنتقل إلي الفصل التالي › حيث ستبني برنامجك الأول. 


مصد, ان للمساعدة ملغات المساعدة المحلة و المحتوی علے ‏ !لانت نت 


لقد جرت تحسينات رئيسية علي محتوي معلومات مساعدة فيجوال ستديو و الأدوات التي تزود وصولا الي تلك 

المساعدة . في الأساس ٠‏ هناك موردان اساسيان للمساعدة الألكترونية من فيجوال ستديوهمiيں†S‏ ام۷¡su‏ : 

° يمكنك الوصول إلي المساعدة المحلية التي تثبيتها خلال عملية اعداد فيجوال ستديو ٠٠٠٠١‏ ( تلك الملفات 
مخزنة علي أقراص تسمي راهطا 5D١N‏ - المكتبة 155۸ - في حزمة البرنامج فيجوال ستديو ) . 

ه٠‏ يمكنك الوصول إلي المساعدة علي الخط ( علي الإنترنت ) من خلال "5D١N‏ › ومجموعة من مواقع ويب 
المطورين ترعاها مايكروسوفت وتدعيı NET Code Wise Azعgnجnئll . NET Code Wise Community‏ 
Community‏ قیمة بشکل خاص تتضمن مطورین محترفین یستعملون فیجوال ستدیو و فیجوال بيسك ۲۰۰٠٣‏ 
لكتابة برامج من العالم الحقيقي › ويجري تحديث المحتويات والنصائح التي يقدمونها باستمرار ولذا فإنها 
تعكس الميول والهموم والأنتصارات الحالية ضمن مجتمع برمجة فيجوال بيسك . 
اضبط تكوين نظام مساعدتك الأن ليقدم لك موارد المساعدة المحلية وعلي الإنترنت أثناء تعلمك عن فيجوال 

ببسڭ . 


4 « 


ضبط خيارات نظام المساعدة :- 


. سه1 لفتح نظام المساعدة‎ 50٥ | ? اختر الأمر‎ -١ 
Microsoft Documents Explorer „awî Hګ†ML‎ aيلع يقدم فيجوال ستديو مساعدته من خلال أداة مرتكزة‎ 
لفتح‎ Help › Commu rity مستكشف مستندات مايكروسوفت ). يمكنك استعمال عدة أوامر من القوائم‎ ( 
مستكشف المستندات . كل أمر يفتح ويضبط تكوين مستكشف المستندات ليعرض نوعا مختلفا من معلومات‎ 
المساعدة . ?| 50 سه ١هو أحد أفضل أماكن البدء › أنه يبين لأئحة هرمية بمهام البرمجة الشائعة التي يمكنك‎ 
: استعمالها لأيجاد المعلومات التي تحتاج إليها بسرعة . تبدو شاشتك مشابهة للتإلي‎ 


| ji ies Baoan a] Hel Ferran ق ا‎ mrn E E | 
Tala major Met Foal : ج‎ : 
E a E E a my < | I > E a mm e | 

دک توا | س ن 
GL SF ai AROS Bink In Formats Hart Fomard‏ 
فة فوت erage‏ . 
a ai Hamî ra SA SY DO‏ 

+ Lemgim ge: Filter rail Eeiha 
ee n E e : ٣ 
BI SL ST Semen Thaw infarmaton Hou are [ryrag boi eı: co ıt be found, erîguzy wren cauld heave caused Has error 
HS Sma Dasher Eray 
BH SE Sea hls Sees Toi hame ciiogen to ae oral e amily For Search awl FI resilîs, arî thie topic 
GB SEL Seria Ig aio Serri zouk eam be oud bî Ioecal HEE 
3 SL Sera Repl. 
H- SL Sea Reqa liej Sera E 
TI - TAL Sere PF slip Ferrie 
BH ST See erate Erebe 
E PFB-Taat SaTh 
B Serirty Corer For 


THE wrrur Can bm cima han local lp hag Tat be¬ Tîm lad ı7 ony a iba of local Help was ria Bad. 


Ti correct his error 
In Hee Tesq lk: rreemag. cik ptr 
8: 3 Ear: rma Hen 7 
واا ا و‎ 3 a n © se Online e Teg eml Fat, hes all. 
Carga ran oF rara 4. In Search Thane providers, ıarify Uu SDA Oallme ır Codazeme Camm anlîy k5 cel acid 
H- Ha Serre Largaege Fafergi 
TI argh ad Sarma Dalaba 
TÎ Tak FA LT Ea Faraz Fal per 
TI EL Gara Frama" Hali TE 
ةتوت ب بو‎ E BNN 
TT 
a-Si SS Tiir aah: 
EH SL Smea Tonk Tula lale 
E ral TET Tiir lake 
TT ais Fim Till 
HB rhein Semere Tiras 
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۲- انقر موضوعا واحداً أو أكثر ضمن اللأئحة ? | 10W 00٥0‏ لاستکشاف نوع المواد E RE‏ 
> يحتوي نظام المساعدة على منات الأوصاف التقنية والمواد التعليمرة ( يتضمن العديد منها مثال ) . 
ستضبط تكوين نظام المساعدة بحيث يعرض فقط المحتوي الذي تريده عندما تفتحه . 

۳ علي شريط القوائم مستكشف مستندات مايكروسوفت › انقر 5 ثم انقر الأمر Options‏ . 
ستري خيارات التخصيص التي يمكنك استعمالها لضبط طريق عمل نظام المساعدة و ( الأهم من ذلك ) ما هي 
as Ca o SE RES Al‏ 
٤‏ - انقر الموضوع ١ا"‏ تحت الفئة مام اذا لم يكن منتقي من قبل . 
تبدو شاشتك متشابهة للتإلي : 
نصيحتي لك هي أن تضبط خياراتك علي الإنترنت كما هو مبين في هذه الشاشة - انها الأعدادات الأفتراضية . أولا 
> انتق زر الخيار الوسطي لتحميل محتوي المساعدة من المصادر المحلية في قرصك الصلب أولاً ثم من المصادر 
علي الإنترنت . تأكد بعدها من ilتقsl NET Aۍzعgaجall ) Code zone Community < MSDN Online‏ 
Wise Community‏ مهد ) لكي يحمل فيجوال ستديو المقالات الحديثة من مطوري فيجوال بيسك كلما 
استعملت الأمر إءإهم5 . اذا وجدت بعد فترة انك تفضل بعض المجتمعات ٥٥۵٠20٥0‏ علي بعضها الأخر › 
يمكنك تعديل ترتيب البحث أو ازالة البنود من اللأئحة . 

ه- انتق خيارات التكوين التي يناسبك › ثم انقر )0 لحفظها . 
يمكنك العودة إلي قائمة ام ضمن مستكشف المستندات في اي وقت يكون نظام المساعدة مفتوحا . الأن 
حأول استعمال ميزة جديدة اخري في فيجوال ستديو ٠٠٠٠‏ . لأئحة مفضلأت المساعدة › تعمل بشكل مشابه 
كثيرا للأئحة المفضلأت ضمن انترنت اكسبلورر . 


القائمة مام فے د نامج 2005 Visual Basic.Net‏ °-' 


¢ 


About Microsoft Yisual SEIdio 


| Help 1elp | 3 
@ How Do1I wkrl+F1 
A Search ctrlralt+F3 | 
df Contents Ctrl+Alt+F1 
Index Ltrl+Alt+FZ 
| F7 Help Favorites w_krl+Alt+F 
@| Dynamic Help ctrl+Alt+F4 
ıl Index Results Shirft+Allt+F2 
wustormer Feedback Options... 
1 Register Product, ,; 
1 heck For Updates 
١ yê Technical Support 
| | 


صيانة لأئحة مفضلات ضمن المساعدة: 


-١‏ علي شريط أدوات مستكشف المستندات » انقر زر الأضافة إلي مفضلاأت المساعدة ( الزر الموجود بجانب الزر 
Hep Far‏ والذي يبين صفحة عليها علامة جمع ). 
عندما تنقر هذا الزر › يضيف مستكشف المستندات المقال المرنى حاليا إلى لأئحة مستندات المساعدة المفضلة 
لديك . يمكنك الأن ابقاء وماردمساعدتك المفضلة منظمة وبمتناول إليد دائما ! 

۲- انقر علامة التبويب إءإaمSŠS‏ کي أعلي اطار مستكشف المستندات . 
يفتح الأطار Search‏ مزودا أداة يمكنك استعمالها لأجراء عمليات بحث نصية محددة ضمن موارد مساعدتك 
المحلية وعلي الإنترنت . 


1 - مايكل هالفرسون » ترجمة مركز التعريب والبرمجة بدار العربية للعلوم : الفيجوال بيسك دوت نت ۲٠٠٠٠١‏ " تعلم خطوة بخطوة " › الطبعة الأولي 


٥٣ص‎ ۰ ۰۰٦ 
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۳- انقر سهم الخيار موعںومجا ( عامل تصفية للمحتوي ) والغ علامات الأختيار عن كل اللغات ما عدا فيجوال 
يمكنك ضبط تكوين نظام المساعدة لجعل بحتك يقتصر فقط علي اللغات والتقنيات والمواضيع التي تريدها 
باستعمال أسهم عوامل التصفية . لأن بدأت باستعمال فيجوال ستديو للتو › فد تريد بحثك يقتصر فقط علي فيجوال 
بيسك في الوقت الحاضر . 

. Enter bخiض›ls‎ Data Controls اتپ‎ «< Search في مربع النصض‎ - ٤ 
يبحث فيجوال ستديو عن السلسلة النصية ءامءİرمء هاه في ملفات مساعدتك المحلية وعلي الإنترنت في‎ 

1 ومجموعات الأخبار والمجتمعات ٠٣z0هله۴.‏ انتبه انتبه جيدا إلي اللأئتحة رع م5 في الأطار 
Search‏ «< التي يمكنك استعمالها لأنتقاء كيف تظهر المقالات التي يبحث عليها البحث . تقول الأشاعات أن فریق 
فيجوال ستديو ۲٠٠٠١‏ بذل جهدا كبيرا لجعل فهم واستعمال نتانج البحث تلك أسهل مما كان عليه في الماضي . 
لأحظ بشكل خاص ميزة فيجوال ستديو ٠٠٠٠١‏ الجديدة التي تنشئ مقتطفا من كل نتيجة بحث معثور عليها . 
يعطيك هذا المقتطف فرصة أفضل لتقييم مدي وثاقة صلة كل نتيجة بالبحث . 

-٥‏ انقر زر حفظ البحث علي شريط أدوات مستكشف المستندات 
تلميح بالضافة إلي مقالات المساعدة › ينمكنك حفظ البحث المهمة في لأئحة مفضلاتك . 
تشبه شاشتك الشكل التالي . لأحظ أن الأطار وءە !مه۴ مام١‏ يتضمن الأن المفضلتين الجديدتين اللتين 

- فة ت‎ 
® Search - Microsoft Visual Studio 2005 Documentation - Microsoft Document Explorer - 
Eile Edt View Tools Window Help 
@ A QQ Hombol ~ 4 search | Index 4% Contents F]Helg Favorites Î ماع د ائھ لوت‎ ۳ A 


Help Fawûrites 


mH Help Topics 
mF" ¥ Language: HTML, YBSrripE, Wisual Basic 


ll Help Searches NET Lompact Framework, . NET Development, 45P, NET, Data Mining Extensions (OMAR, Mobile & Embedded, 

EE Multidimensional Expressions (MOR, Office Development, Seryers & Enterprise, SAL Server ZODD, SQL Server 
ZUUS, SAL Server Analysis Services, SQL Server Data Mining, SQL Server Database Engine, SAL Server 
Integration Services, SQL Server Mobile, SQL Serwer Notification Services, S4L Server Replication, SAL Server 
Reporting Services, Transarct-SAL, Yisual Studio 2#UU5, Web Development, Winda & ZOM, Windows Forms, 
Windows Wista 


„Search | Information Not Found | 


¥ Technology: 


| wl Zontent Type: #ۉl‎ 
Searched For: : O-O of Û results 


1 Currently there are no search results to display. 
5 Lreakte a help search by entering a kerm in the Search box aboye and û Local Help 
pressing the Search button. 


MASON Online 


Index ResulEs 


Title Location 


٭ 


Ready 


-٦‏ انقر زر تغيير الأسم في الأطار ماج۴ مام ( يمكنك أيضا نقر بإليمين البحث الذي حفظته › ثمي انقر 
Rename‏ ( 
يميز مستكشف المستندات الأسم الذي استعملته لبحنك ويتيح لك تغييره لكي يطابق البحث الفعلي بدقة أكبر . قذه 
الخطوة اختيارية › لكنني أجدها مفيدة . 

- اتپ Enter طbضlg Binding Data to Controls‏ . 
يغير مستكشف المستندات اسم البحث ضمن لأئحة مفضلأتك . لقد اخترت هذا الأسم لأنه بدا أوضح لي من سلسلة 
بحثي الأصلية (لكنك قد تريد تحديد اسم مختلف يطابق بدقةأكبر نتائج البحث التي أرشفتها ) 

۸- انقر ?۱ 50 سم۳1 في Îlأb¦طlر Help Favorites‏ . 
يظهر أأول مقال حفظته في مستكشف المستندات . ستتمرن الأن علي حذف مفضلة › وهذه مهارة تصبح مهمة 
عندما تنمو لأئحة مقالات مساعدتك المفضلة وتحتاج إلي تصغيرها . 
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۹- انقر زر الحذف في !Îأb¦طlر Help Favorites‏ . 


. اذاطلب منك تأكيد نتك بحذف هذه المفضلة › انقر وم۷‎ -١ 
) سه1 من لأئحة مفضلأتك ( ولكن ليس من نظامالمساعدة‎ ٥0 | ? يحذف المقال‎ 

-١‏ انقر زر الإغلاق علي شريط علي شريط عنوان مستكشف المستندات. 
هناك ميزات المساعدة اضافية لتتعلم عنها وتختبرها › لكن الوقت جيد الأن لكي ألخص لك أوامر المساعدة 
المهمة ولكي تنتقل إلي كتابة أول برنامج لك في الفصل ٤٠‏ . 


Dynamic Help 
ا‎ Hay Do I QA Search ا‎ Index: 3 _oantenks 


No links are ayailable for the current selection. 


تلخبص أوامر المساعدة :' 


إليك لأنحة قصيرة بأوامر المساعدة المفيدة واستعمالاتها ضمن بيئة تطوير فيجوال ستديو 2005 Basi.‏ اجVisu‏ : 


Help |‏ 
لتنظيمها حب رمهمة #البرمجة êl How Do 1 ctrl+F1‏ 
طاليحت جن كلسة محددة A, Search ctrl+Aalt+F3‏ 
حب الم صو او #النشاط TF Contents ctrl+alt+F1‏ 
سیب الفهر. اا Ly Index Ctrl+alt+F2‏ 
بالقانسة اأحفصا طت Help Favorites Ltrl+Alt+F‏ |3 
چن الميزية او الامر فلت عاك الا Dynamic Help Ctrl+Alt+F4‏ |@ 1 
dl Index Results SHIFEFALHFE‏ 


wustormer Feedback. Options... 
Register Product... 
heck. For Updates 


1 ta Technical Support 


1 لے ظلے رد عد امف ` | 
للحصول کا ت | About Microsoft Yisual Studio‏ 


Help القانمة‎ Moma 2 cussej 


لحصول علي معلومات مساع؟ 

لتنظيمها حسب مهمة البرمجة اآختر الأمر ?| ۲0 ۳٥W‏ † مام١‏ في الفيجوال ستديو 

عن الميزة أو الأمر الذي تستعمله حالياً أختر الأمر مام٣‏ اص ةرط غ مام1١‏ في الفيجوال ستديو 

حسب الموضوع أو النشاط |ختر الٺaر Help Contents‏ في الفيجوال ستديو 

أثناء العمل في المحرر الشفيرة أنقر الكلمة الأساسية أو الجملة البرمجية التي تهمك › ثم اضغط ۴1 

۰ نقر زر المساعدة (علامة أستفهام) فى بعت بعا“ ند 

SS lM SER LSE SERE E N أثناء العمل في مربع الحوار‎ 

مربع الحوار الدي يظهر عندما تختار الأمر Tools ‡ Option‏ 

. أختر الأمر ۲ءإمم؟ ‡ مام و أكتب المصطلح الذي تبحث عنه‎ eT 
چ‎ E : 5 باليحث عن كلمهة اساسيه‎ 
کے س س س قم بتصفية و تنظيم البحث بأستعمال اللأئحة رع ام5‎ 


Code gÎ Developer Center رقil‎ « Community ۂnئlقll من‎ EIR : 
Zone Community من 55۸ مواقع ويب فيجوال ستدیو‎ 


عن الأتصال بمايكروسوفت للحصول علي دعم المنتج | İخüتر‏ |Jٺمر Help Technical Support‏ 


أ - مايكل هالفرسون » ترجمة مركز التعريب والبرمجة بدار العربية للعلوم : الفيجوال بيسك دوت نت ۲٠٠٠٠١‏ " تعلم خطوة بخطوة " ٠‏ الطبعة الأولي 


٥۸ص‎ ۰ ۰۰٦ 
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كيف يمكنك الحصول علي المعلومات ؟! 


قائمة ناهم المهاقع الى رة ال > الحےص : المعلهمات حuدة:‏ 


¢ 


Domain , Link Site طبlرلl‎ Site Name gعقژgnl! سم‎ Site L)⁄¡60 شعار الموقع‎ 
www.cb4a.com کتب‎ 
www.kutub.info/library/list.php?cat=1 حيث تكمن المعرفة‎ 


Wi erer kuru kb. Îmr 


برص اظيا 


موقع دليل العرب الشامل www.star28.com‏ 


موقع شبكة كتاب العرب www.university.arabsbook.com‏ 


CAARAE‏ موقع الموسوعة العربية للكمبيوتر 


RE‏ شل أ 7 والإنترنت 


www.absba.info 
www.absba.org 


www.c4arab.com 


http ://edu.arabsgqate.com/index.php? ا منتدى شبكة بوابة العرب‎ FADS saate 
اا ا ل عرزب‎ 


www.bramjnet.com 


منتدى الفريق العربي للبرمجة www.arabteam2000.com‏ 


منتدی دی في دی فور أرب www.dvd4arab.com‏ 


موقع التعليم بالفيديو المجاني www.freelearn.110mb.com‏ 


Free Learn 


ت موقع ومنتدی 


WE WE THE ANSWER! 


www.ask-pc.com 


منتدى الفيجوال بيسك 


و www.vb4arab.com‏ 
وهو متخصص هى الاأكواد الفيجوال e.‏ 
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Domain , Link Site طڊlرلl‎ Site Name gۓۃقژgnl! س‎ Site L)⁄¡60 شعار الموقع‎ 


5 فدلة اة ,. 
۹ 0 الوط الغربيف منتديات المحيبط العربى www.qemin q-corp.com‏ 


aa lÎ ml le all Ay jh 


salem 1‏ منتديات سالم للتكنولوجيا www.salem4it.com‏ 


www.salem4lt. COM 


موقع فيجوال سي للعرب 


http ://www.vc4arab.com)/ 
وهو متخصص فى الأكواد الفيجوال‎ 


واد الف وادي التقنية www.itwadi.com‏ 


ه9 u‏ لمعرفة أخر أخبار تكنولوجيا 
محرك بحث للأكواد البرمجية 
http ://www.krugqle.or e ey‏ 


NUD //WWW.TAareSSOTT.COM/ ۰ 
http //www.faressoft.cOm/ البرمجة‎ 


علي أكبر مجموعة البر امج http ://mawsoaa.faressoft.com/‏ 
المساعدة للتعلم البرمجة 


منتدى صيد الفوائد من المنتديات http-//saaid.net/booK/list.php?cat=100‏ 
NUPp.//Saald.NEUDOOK/IST.pNp ؛cat=1UU E.‏ 
القوية في المجال saaid.net/book/lis ca‏ 


1- www.msdn.microsoft.com/vbasic/ 

2- www.devx.com/ 

3- www.microsoft.com/learningq/books/ 
4- www.microsoft.com/learning/trainingd/ 
5- www.microsoft.com/communities/ 


6- hittp://www.vbkeys.com/ 


كت الب محة للغة الفىحها| بسك دوت نت ف الف وع الأتة٠-'‏ 


البرمجة بلغة فيجوال بيسك .٠٠٠٠١‏ 

برمجة قواعد البيانات مع ام١.۸500.‏ 

برمجة صفحات الإنترنت ۸S۲.‏ . 

البرمجة ڊأغ .Visual Basic for Applications‏ 
كتب عامة عن برمجة الكمبيوتر. 


LEAN‏ چ 


أ - مايكل هالفرسون » ترجمة مركز التعريب والبرمجة بدار العربية للعلوم : الفيجوال بيسك دوت نت ٠٠٠٠١‏ " تعلم خطوة بخطوة " › الطبعة الأولي 


٥٥٦ص‎ ۰. ۰۰٦ 
٥٦۰ص‎ » مرجع سابق‎ - ˆ 
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أحسن ما تعلمت منه اآساسیات البرمحة '"'برامج موسوعة الميرمج العربى ":- ١‏ 


قارس سوقت - موسو عة الميرمج العريي 


فارس سو فقت 


موسوعة المبرمج العربي 


مميزة مختارة من منتديات الفيجوال البيسك العريية 


4ا a‏ وا لہ ے س a4‏ اہ س1 ر کے س لے صو 


قار س سوقت موسو عة الميرمج الحريي -موسوعة الأكواك اليرمجية 


IEEE 


كود سيط لجعل الفورم في المقدمة ٠‏ 
ور الشورم باحجام وآلوان عشواتة 

ثولید فورم من داځل ٻرنامجك 

عمل مؤثرات على الشورم 

إزالة أبغونة فاتبة النظام من النافدة 

تخبير حجم ادوا بلخير حجم النافذة 

تبات حجم النمودج مج لير دف الشايدة 

و سيط النمردج 

إنهاء نافذة بگل محنوبانها 

لحدید نافد ابن بواسطهة عنوانچا 

لحدید نافد بواسطة عنوانچا 

شحدید با لذا كانت النافدة ابن لخبر غا آم 

لحديد ما إذا كان ميض النافدة صحبح أع ل 

إزالة زر + و عنصر غلاق من فاقمة النظام للنافذة ابن 
إزالة زر ١‏ و عنصر لغلا من فاتمة النظام للنافذة 
لإبغاء النافذة شي الماغدية 

لحریكت نافد بدون ربط عنوان 

ثاأثير إنغجار علي الناغذة 

لحمل نمودج شاف 

تلخدام أداذ دااد ] للحربك النافذة مثل شريط العنوان 


ا 


, Viewed 27/1/2009 
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قاريس سوقت - موسو عة الميرمح العريي - المرجع الشامل للدوال اليرمجية 


رحج القيبة المطلغة لي عدد ولرجعة من ناس نوج الببانات المعطي للدالة والمتصود بالغبوة ار 

المطلغة شي فيمة العدد بدون لإشارة فالقمة المطلغة ل ]1١-[‏ مثلا شي ]1١[‏ وغكذا. App.Path‏ 
ولاحظ آن الشيمة المدخلة للدالة لايد أن لكون عدب آر الحبير عددي ادا كانت الغيبة المدخاة I‏ 
للدالة ااال ستكون النتيجة ااال وإذا كانت الغيمة المدخلة للدالة ملخير فارخ أو لم يلم عيبن ۱ 8 
ثبب لك سدکون الئئيجة [ +[ 

راح الدالة ايضا نة فهائين الدالثين تسبي دوال الاشارة 


MyHuurmberzA4b3[-45. B5] 
masqbo« Mp uumber 


فلن نيجه تنغيذ الداله شي 
My Mumber=43. E‏ 


فارس سوقت - موسوة الميرمج العريي - موسو عة الثتب اليرمجية 


اخالرف و اغد انات تي یجول پیا 
التحابل مث وساتط ال 

ت ال تي ادیرعی 

درسين ملغدمين في الضحجرال بييسك 1 

ربط شو اعد الببانات سس بالشحرال بسك 
دور كابلة بالصور في الغبحوال بيسك 1 
صناد يي الرساتا اني الشحوال بيسك ومعناغا 
دو ال الصوت اللدبچي 

يحول بسكت والتعامل مچ بلشات وورد واگسل 
N SE e‏ 

كنابة أول برنامج لك في الشيجوال بيسك 
انشاء برنامج جدید من ډاځل برنامجك 
فيجوال بيسك من لحت الصفر 

كناب شروحات الغيحجوال بيسك 1 

نعلم الگریسئنال ربورت 
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0 


الحجم الكامل ( ٠١۸‏ ميجا بايت ) مقسمة إلى جزأين. 


3 1 2 ا 1 E1 ar LE.‏ = 
أ۴ TST WE El EHO j‏ فل اسا سس الس قت 8 لل ب E‏ 
| س 1 


(Î ٠: ي‎ 7٣ لامد ار ا ادا‎ Î Porites 6 û4-Š E - 8 


إصالات ارط مرقت نا مرااا 


ENTE 


ا وا س 1 و نتفر طا ګر ا NIA ITA‏ 1 1 
LIE îra‏ 


i TT 1 1 ١ 1 £ 5‏ 
فتك تحفيل البرتافج فن اه العر اكع الاد : 


امه انشا اللي يمم شليها لرتامع : 


Û teral 
E١ سا ج .هسبال توا الظمر ا‎ 


سوف تقوم أولً بإدخال البيانات وهى ( الأسم - الدولة - المدينة - البريد الألكتروني ) ثم تدخل على المواقع ثم تبدأً بالتحميل. 


من خلال تحميلي من الموقع وجدت أفضل الروابط هو ٤ءإجهطS؟ل¡مهR۸.‏ 
للتحميل المباشر من الموقع... 


LE PR I I 


RARIDSHA It 


الرابط الأول (مساحتها ۸۰ ميجا بايت ) 


. 


aT 
N CS ET 
"HN2 ^0ON?7/ آ‎ 

CC. 1/ HES‏ ا 


< 1al 


الرابط الثانى (مساحتها ٤۸,٦‏ ميحا بايت ) 
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الاهداف ' 


الملحق الأول: 


ه التعرف على لغة الأستعلامات البنيرية اSQ.‏ 
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الأهراق 
فى نهاية دراسة هذه الملاحق » يحب أن يكون الدارس قادرا على أن : 


.Sها بعرف أهية لغة الأستعلامات‎ - ١ 

١‏ - فرق بن أوامر ا8۵ و تصنيفاقا. 

۴ - يستخدم أوامر الربط البيانات فى الأستعلامات. 

» - يستخدم أوامر التجميع البيانات عند الأستعلامات . 

٥‏ - یستخدم أوامر الفرز البيانات. 

٠‏ - يستخدم الدوال التجميعية. 

۷- یستخده أوامر الأنشاء لقاعدة البيانات والجدول. 

۸-يستخدم أوامر الحذف لقاعدة البيانات والجدول. 

٩‏ - يستخدم أوامر التعديل لقاعدة البيانات والجدول. 

-٠‏ إيُصمم الأستعلامات و الفهارس للحصول علي البيانات. 

- يستخده أوامر إدخال البيانات للبيانات. 

-١‏ يجري العمليات الحسابية والمنطقية للبيانات. 

١‏ - يستخدم المعاملات والفرق بينهما في الحصول علي البيانات المطلوبة. 
4 يفرق بن الربط والدمج بأنواعه. 
-٠‏ يتعرف على المصطلحات الأنجليزية الصعبة في البرجة والبرنامج. 
-٠١‏ يتعرف على الأختصارات الأنجليزية في البرنامج. 
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(للعن زرل 
رر عل لھ (رس رر 
SOL‏ 


التعرف علي لغة الأستعلامات اه5 


لغة تستخدم في 2005 Basi ٥.‏ ا۷isua‏ عند استخدام وہ¡ ۸0NE 2 Progra‏ للتعامل لربط البرنامج 
بقواعد البيانات. 


الأهداف: 


بعد إكمال هذا الملحق » ستتمكن من تنفيذ ما يلي : - 


۷- معرفة أهمية لغة الأستعلامات |ا5Q.‏ 

۸- الفرق بين أوامر 5۵1 و تصنيفاتها. 

۹- أستعمال أوامر الربط › التجميع > الفرز. 

-٠‏ أستخدام الدوال التجميعية. 

-١‏ أستخدام أوامر الأنشاء › الحذف » التعديل لقاعدة البيانات والجدول. 

-۲١‏ أنشاء الأستعلامات و الفهارس للحصول على البيانات. 

۴۳- أستخدام أوامر إدخال البيانات › الحذف » التعديل للبيانات. 

-٤‏ أجراء العمليات الحسابية و المنطقية للبيانات. 

-٠‏ أستخدام المعاملات والفرق بينهما في الحصول علي البيانات المطلوبة. 
-١‏ معرفة الفرق بين الربط › الدمج بأنواعه. 


مايكروسوفت فيجوال بيسك ۲٠٠٠‏ هو ترقية و تحسين مهمين لنظام تطوير الفيجوال بيسك ٠‏ و ترقية تكرارية لبرنامج 
الفيجوال بيسك ٠٠٠۳‏ دوت نت و يعطيك الملحق القدرة علي معرفة لغة الأستعلامات اه5. 


و تستخدم عند ربط الفيجوال بيسك بقواعد البیانات و تستخدم وہ¡ AD0.Ne۲ 2 r٥a‏ و التعامل مع المکتبات 58ءا0) 
( ۸۲ا٥‏ , واستخدام التصنيفات التي تستخدم لربط قواعد البيانات بانواعها مثل:- 


SQL Server 2000 OR 2005 
Oracle 

My SQL 

Ms Access 2000 OR 2003 


هذه هي البرامج التي تستخدم لغة الأستعلامات اه5. 
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Content ceil 
مقدمة عن لغة الأستعلامات الهيكليه ا80‎ 


الحزء الأول : " أوام معالحة السانات " 0×1 : 
Select l> °‏ 
٠‏ عبارة الشرط Where‏ 
٠ه‏ معامل م )زا فى الشرط 
ه أمر أضافة صف فی الجدول oاہ!‏ أمsہ!ا‏ 


٠‏ أمر التعديل فى الجدول مtھولdم‏ ل 
ه أمر الحذف من الجدول امام 


: SQL Function ı lJ اب المتقدمة وہ دولا‎ 


٠ه‏ عبارة الترتيب رع مك0 

ه المعاملين إ0 - and‏ 

المعامل »| 

Between ..... and ه المعامل‎ 

٠‏ الأسم المستعار وهنا 

Union and Union All| الدمج بإستخدام‎ 
SQL Function Jll 


SQL Group By and Having jرفنlو ه التجميع‎ 


ام تی نف السانات " اا٥‏ : 


هم أنشاء قاعدة ائبيlنGlٽ Create Database‏ 

ه أنشاء جدول في قاعدة البيانات ماIab Create‏ 
® iîشlء‏ فqرس Create Index‏ 

٠‏ أمر الحذف مهاد 

ه أمر التعديل على الجدول ماطه۲ ۲٥ا۸‏ 


Select Into جملة‎ 6 
Create View مںعتwÎ‎ sil 
المر احح‎ 
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جاسم الله الوحمن اأوحدم 


أولا مقدمه في _[هS:‏ 


هي لغه قياسيه من لغات الحاسب لدخول ومعالجه قواعد البيانات 


ما هي Structured Query Language : SQL‏ 
لغه بناء الأستعلامات الهيكليه :- 


ANS| هى لغه قياسيه من لغات الحاسب الخاصه بمعهد‎ -١ 
تمكنك من الدخول لقواعد البيانات‎ - 

۳- تمكنك من إستخراج البيانات من القاعده 

-٤‏ تمكنك من إضافه بيانات إلى قاعده البيانات 

ه- تمكنك من من حذف بيانات من القاعده 

-٦‏ تمكنك من تعديل البيانات المسجله 

۷- أخيرا هي لغه سهله التعلم والفهم 


لغه 1ا5۵ هي لغه قیاسیه : 

هى لغه من اللغات القياسيه الخاصه بمعهد 
ANSI (American National Standards Institute)‏ 
تمكنك من دخول ومعالجه نظم قو|عد llبlilıت Database System‏ 
جمل 1ا5۵ تعمل مع برامج قواعد البيانات مثل : 


Ms-Access , Ms-SQL Server , DB2 , Oracle ,؛SQL‎ Server 2000 OR 2005 , etc. 
: تنقسم لغه 501 إلي قسمين‎ 
SQL Data Manipulation Language (DML) =1 


هو القسم المسئول عن : معالجه البيانات 


-١‏ اءمامS‏ : إستخراج البيانات من قاعده البيانات 
|NSERT |70 -1‏ : إضافه بیانات جدیدہ 

Update -۳‏ : التعدیل علي البيانات المسجله 

“؛- Delete‏ ` حذف البيانات من القاعده 


2- Data Definition Language (DDL) 
هو القسم المسئول عن : تعريف البيانات‎ 


Create Database =`‏ : لأنشاء قاعده بیانات جدیدہ 
1- eاrab Create‏ : لأنشاء جدول داخل قاعدہ بیانات 
۳- ماطهt Alter‏ : للتعديل في الجدول 

“- ماهt‏ مها : لحذف الجدول من قاعده البيانات 
Create index -°‏ : لأنشاء مفتاح للبحث 

-٦‏ ×eلnہi‏ pاD‏ : لحذف مفتاح البحث 
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SQL Data Manipulation Language (DML) الجزء الأول "معالجa lأبيlilت" ب‎ 


Select 4ذiمج‎ 


تستخدم في إستخراج بيانات من داخل الجدول حسب المطلوب 


تكتب الجمله كالتالي: ×جا"رS‏ 


SELECT column_name(s) 
FROM table name 


١‏ ملأحظه هامه : جمل |50 غير حساسه لحاله الحروف 
ل يوجد فرJ SELECT = select‏ 


مثال علي الجدول التالي : 


The database table "Persons'": 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Svendson Tove Borgvn 23 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


نريد أختيار الأسم الأول و الأسم الأخڍıر (FirstName , LasName)‏ 
تكتب الجمله كالتالي : 


SELECT LastName,FirstName FROM Persons 
: ويكون الناتج كالتالي‎ 


النتیجہ :tاAesu‏ 


LastName FirstName 
Hansen Ola 
Svendson Tove 
Pettersen Kari 


لأختيار جميع البيانات تكتب كالتالي : 
SELECT * FROM Persons‏ 
وتكون النتيجه كالتالي : 


النتیجھ :tاuںsuمR‏ 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Svendson Tove Borgvn 23 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


ملأحظه هامه : بعض نظم إداره قواعد البيانات تتطلب وجود ( ; ) في نهايه جمله 5601 وهذا لأن بعض النظم تدعم تنفيذ أكثر من 
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الأن نندرج لجمله أخري أو إضافه لجمله S٤ 1_٤٥7‏ وهي جaذ4 SELECT DISTINCT‏ 


إضافه كلمه 015۲|٧١‏ للجمله تمكنك من العرض القيم بدون تكرار (يعني لو الجدول فيه بيان متكرر اكتر من مره بتعرضه مره 
واحده بس) . 


مثال : علي أستخدام 0157|١٧‏ وعدم أستخدامها 
SELECT Company FROM Orders‏ 


"Orders" table 


Company OrderNumber 
Sega 3412 
W3Schools 2312 
Trio 4678 
W3Schools 6798 
Aesuا†: النتیجه‎ 

Company 

Sega 

W3Schools 

Trio 

W3Schools 


0۱8۲|٧7 هنا واضح الفرق عند أستخدام‎ 
SELECT DISTINCT Company FROM Orders 
Rموںuاi: النتیجه‎ 


Company 
Sega 
W3Schools 
Trio 
الأن ننتقل لجزء اخر الأ وهو استخدام الشرط‎ 


Prog: Mohamed Youssef ۱۸۹ E_Mail: Mohamed.yoyo@gmail.com 


استخداھم عبار »` WHERE‏ 
تأتي بعد جمله 1٠ء٠ام5‏ وتحتوي علي الشرط المطلوب ويكون بنائها بهذا الشكل : 


Syntax 


SELECT column FROM table 
WHERE column operator value 


مع جمله ١/1٠۲١‏ يمكننا أستخدام المعاملات الأتيه : 


المعامل الوصف 

= يسأوي 

<< لأ يسأوي 

> أكبر من 

< أصغر من 

=> أكبر من أو يسأوي 

=< اصغر من أو يسأوي 

Between‏ يكون الشرط بين قيمتين 

LIKE‏ للبحث عن كلمات متشابهه 


! ملأحظه هامه : في بعض الأصدارات من ا50 المعامل< يكتب هكذا‎ r 
۷۸٥۲۲ مثال علي أستخدام عباره‎ 


SELECT * FROM Persons 
WHERE City='Sandnes' 


"Persons" table 


LastName FirstName Address City Year 
Hansen Ola Timoteivn 10 Sandnes 1951 
Svendson Tove Borgvn 23 Sandnes 1978 
Svendson Stale Kaivn 18 Sandnes 1980 
Pettersen Kari Storgt 20 Stavanger 1960 
النتیجھ ا ںیم‎ 

LastName FirstName Address City Year 
Hansen Ola Timoteivn 10 Sandnes 1951 
Svendson Tove Borgvn 23 Sandnes 1978 
Svendson Stale Kaivn 18 Sandnes 1980 


7 ملأحظه هامه : علي أستخدام علامه التنصيص مع الجمله ( ' )يجب أستخدام علامه تنصيص مفرده مع القيم النصيه مثل 
الأسماء اما بالنسبه للبيانات الرقميه تكتبه من دون علامات . 
مثال علي ذلك : 


For tex values: للبيانات النصي4‎ 


This is correct; طريقه صحي4‎ 
SELECT * FROM Persons WHERE FirstName='"Tove' 


طریقهھ خاطنہ :وہس is is‏ 


Prog: Mohamed Youssef ۱۹۰ E_Mail: Mohamed.yoyo@gmail.com 


SELECT * FROM Persons WHERE FirstName=Tove 
For numeric values: للبیانات اأرقمي4‎ 


This is correct: طريقه صحي4‎ 

SELECT * FROM Persons WHERE Year>1965 
This is طریقه خاطھ : وہ ہس‎ 

SELECT * FROM Persons WHERE Year>'1965' 


استخدام المعامل مزا الش طط 


تخدم في تحديد البحث بکله ۾ معینه مثال البحث عن كل الأسماء الموجود بها حرف أو كلمه معينه . 


"٤2×‏ 5yبنائھا‏ بهذا الشکل 


تستخدم علامه (% ) لتحديد عدد الحروف قبل و بعد الكلمه أو الحرف الذي نبحث به مثال : 
في هذه الحاله سوف تظهر اسماء الأشخاص التي تبدا بحرف ۸ ثم يأتي بعدها اي عدد من الحروف 


SELECT * FROM Persons 
WHERE FirstName LIKE 'a%' 


في هذه الحاله سوف تظهر اسماء الأشخاص التي تنتهي بحرف ۸ ويكون قبلها اي عدد من الحروف 


SELECT * FROM Persons 
WHERE FirstName LIKE '%a' 


في هذه الحاله سوف تظهر اسماء الأشخاص التي تحتوي علي حرف ۸ في أي موضوع في الأسم 


SELECT * FROM Persons 
WHERE FirstName LIKE '%a%' 


بقي لنا الجزء الخاص ب 8٥« ٠٠١‏ وسوف نندرج إليه فيما بعد. 
الأن ننتقل لجزء جديد الأ وهو التعامل مع البيانات 
يوجد لدينا ثلأئه تعاملأت مع البيانات 

INSERT INTO : إضاف4‎ -\ 

UPDATE : Jيدعتٿ‎ -۲ 

DELETE ; ھذف‎ -۳ 


إضافه صف للجدول : INSERT INTO‏ 


يكون بنائها كالتالي : 


Syntax 


ويمكنك ايضا تحديد الحقول المطلوب إضافتها فقط وتكون كالتالي : 


Prog: Mohamed Youssef ۱۹۱ E_Mail: Mohamed.yoyo@gmail.com 


مثال إضافه صف جديد للجدول التالي : 


This "Persons" table: 


City 
Stavanger 


النتيجه تكون كالتالي : 


City 
Stavanger 
Sandnes 


VALUES (value1, value2,....) 


LastName FirstName Address 
Pettersen Kari Storgt 20 


INSERT INTO Persons 
VALUES (Hetland', 'Camilla', 'Hagabakka 24', 'Sandnes') 


LastName FirstName Address 
Pettersen Kari Storgt 20 
Hetland Camilla Hagabakka 24 


لأضافه بيانات في أعمده (حقول) محدده فقط تكتب كالتالي : 


تكون النتيجه كالتالي : 
City‏ 


Stavanger 
Sandnes 


يكون بناء الجمله كالتالي : 


Syntax 


مثال علي التعديل علي الجدول الحالي : 


Person: 


City 
Stavanger 


لأضافه الأسم الأول في الصف الثاني : 


INSERT INTO Persons (LastName, Address) 
VALUES ("Rasmussen', 'Storgt 67’) 


LastName FirstName Address 
Pettersen Kari Storgt 20 
Hetland Camilla Hagabakka 24 
Rasmussen Storgt 67 


التعديل فى الجدوJ‏ : UPDATE‏ 


UPDATE table name 
SET column_name = new value 
WHERE column_ name = some value 


LastName FirstName Address 
Nilsen Fred Kirkegt 56 
Rasmussen Storgt 67 


UPDATE Person SET FirstName = 'Nina' 
WHERE LastName = 'Rasmussen' 


Prog: Mohamed Youssef 1۹۲ E_Mail: Mohamed.yoyo@gmail.com 


City 
Stavanger 
٠ لأضافه أسم المدينه وتغير العنوان‎ 


City 
Stavanger 
Stavanger 


النتيجه :†إsuمAR‏ 


LastName FirstName Address 
Nilsen Fred Kirkegt 56 
Rasmussen Nina Storgt 67 


UPDATE Person 
SET Address = 'Stien 12', City = 'Stavanger' 
WHERE LastName = 'Rasmussen' 


النتيجه :إResu‏ 


LastName FirstName Address 
Nilsen Fred Kirkegt 56 
Rasmussen Nina Stien 12 


الحذف من الجدول : D‌٤_ ٤۲۴٤‏ 


تستخدم في حذف الصفوف من الجدول وبنائها كالتالي : 


Syntax 


مثال علي حذف صف من الجدول : 


Person: 
City 
Stavanger 
Stavanger 
لحذف الصف‎ 
City 
Stavanger 


لحذف جميع البيانات ( الصفوف ) من الجدول 


تستخدم الجمله التاليه : 


E_Mail: Mohamed.yoyo@gmail.com 


DELETE FROM table name 
WHERE column_name = some_value 


LastName FirstName Address 
Nilsen Fred Kirkegt 56 
Rasmussen Nina Stien 12 


DELETE FROM Person WHERE LastName = 'Rasmussen' 


Resul النتيحه:‎ 
LastName FirstName Address 
Nilsen Fred Kirkegt 56 


Prog: Mohamed Youssef ۹۳ 


الحرْ ع الثائے, الخا 


SQL FUNCTION — 


في هذه المرحله من الشرح سوف نبدأً في التعامل بمرونه أكثر مع قاعده البيانات عن طريق إضافات لما تم شرحه في الجزء 


الأول من الدرس عن طريق جمل ا50 


Order By : ®. عبار‎ 


تستخدم لترتيب الناتج من الأستعلام حسب حقل محدد 
مثال علي التريب : 
Orders:‏ 


سنقوم بتنفيذ جمله الأستعلام التاليه : 


نلأحظ ان البيانات جائت في ترتیب حسب حقلرہ 2م۳۸٥٥‏ 


إذا اردنا الترتيب بأكثر من حقل تكون كالتالي : 


ماذا لو اردنا عكس الترتيب كيف يتم ذلك 
مثال : 


E_Mail: Mohamed.yoyo@gmail.com 


Company OrderNumber 
Sega 3412 
ABC Shop 5678 
W3Schools 2312 
W3Schools 6798 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company 


النتیجھ :tاuںsمA‏ 


Company OrderNumber 
ABC Shop 5678 
Sega 3412 
W3Schools 6798 
W3Schools 2312 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company, OrderNumber 


النتیجھ :tاuںsمR‏ 


Company OrderNumber 
ABC Shop 5678 
Sega 3412 
W3Schools 2312 
W3Schools 6798 


Prog: Mohamed Youssef 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company DESC 


النتيجه :اإاuںومR‏ 

Company OrderNumber 
W3Schools 6798 
W3Schools 2312 

Sega 3412 

ABC Shop 5678 


في حاله اننا نريد أستخدام الطريقتين كيف يتم ذلك 


مثال : 
يمكن عمل ذلك بطريقتين 
الطريقه الأولي : 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company DESC, OrderNumber ASC 


اما الطريقه الثانيه هي كتابه الحقول المطلوب ترتيبها تصاعديا أولاً ثم الحقول المطلوب ترتيبها تنازليا 
مثال : 


SELECT Company, OrderNumber FROM Orders 
ORDER BY OrderNumber , Company DESC 


وفي اي من الطريقتين تكون النتيجه واحده 


النتیجہ i:‏ اuںومR‏ 
Company OrderNumber‏ 
W3Schools 2312‏ 
W3Schools 6798‏ 
Sega 3412‏ 
ABC Shop 5678‏ 
الأن ننتقل لمعاملات جديده 
المعاملين 08 - Ad‏ 
يستخدم هذين المعاملين في ربط شرطين أو أكثر:- 
- المعامل ۸١5‏ يقوم بعرض النتائج في حاله تحقق جميع الشروط 
- المعامل 0۸ يقوم بعرض النتائج في حاله تحقق اي شرط من الشروط 
مثال : علي الجدول التالي 
LastName FirstName Address City‏ 
Hansen Ola Timoteivn 10 Sandnes‏ 
Svendson Tove Borgvn 23 Sandnes‏ 
Svendson Stephen Kaivn 18 Sandnes‏ 


Prog: Mohamed Youssef 1۹° E_Mail: Mohamed.yoyo@gmail.com 


أستخدام المعامل AND‏ : 


City 
Sandnes 


أستخدام المعامل 0۸ : 


City 
Sandnes 
Sandnes 


أستخدام المعاملين معا : 


City 
Sandnes 
Sandnes 


له عده أستخدامات منها انه يمكنك تحديد القيمه المراد عرضها إذا كنت متأكد من وجودها في أحد الحقول 


بناء الجمله ٠‏ 


مثال : علي الجدول التالي 


City 
Sandnes 
Sandnes 
Stavanger 
Sandnes 


E_Mail: Mohamed.yoyo@gmail.com 


Address 
Borgvn 23 


Address 
Borgvn 23 
Kaivn 18 


Address 
Borgvn 23 
Kaivn 18 


SELECT * FROM Persons 
WHERE FirstName='Tove' 
AND LastName='Svendson' 


Rمsuاt: النتیجه‎ 
LastName FirstName 
Svendson Tove 


SELECT * FROM Persons 
WHERE firstname='Tove' 
OR lastname='Svendson' 


النتیجه :tاuںsuمA‏ 


LastName FirstName 
Svendson Tove 
Svendson Stephen 


SELECT * FROM Persons WHERE 


(FirstName='Tove' OR FirstName='Stephen') 


AND LastName='Svendson' 


النتیجہ :tاsuمA‏ 


LastName FirstName 
Svendson Tove 
Svendson Stephen 


|١ المعامل‎ 


Address 
Timoteivn 10 
Neset 18 
Storgt 20 
Borgvn 23 


SELECT column_name FROM table_name 
WHERE column_name IN (value1,value2,..) 


LastName FirstName 
Hansen Ola 
Nordmann Anna 
Pettersen Kari 
Svendson Tove 


SELECT * FROM Persons 
WHERE LastName IN ('Hansen',' Pettersen’) 


Prog: Mohamed Youssef 


النتیجہ :tإاuں‌یمR‏ 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


ويمكن أيضا أستخدامه في ربط أكثر من أستعلام معا 


في هذا المثال قمنا بعرض جميع القيم من الجدول الأول 
e1_nameاط۲a‏ بشرط ان یکون الحقل 12۳ء۴۲ موجود 
في الجدول الثاني مهم 2اط 


الnعاJa BETWEEN ... AND‏ 
يستخدم لعرض مجموعه بيانات بين قيمتين نصوص أو أرقام أو تاريخ 


بناء الجمله ٠‏ 


مثال : علي الجدول التالي 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Nordmann Anna Neset 18 Sandnes 
Pettersen Kari Storgt 20 Stavanger 
Svendson Tove Borgvn 23 Sandnes 


عرض البيانات الموجوده بين القيمتين 


SELECT * FROM Persons WHERE LastName 
BETWEEN 'Hansen' AND 'Pettersen' 


النتیجھ :tاuںsuمRe‏ 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Nordmann Anna Neset 18 Sandnes 


عرض البيانات الغير موجوده بين القيمتين 


SELECT * FROM Persons WHERE LastName 
NOT BETWEEN 'Hansen' AND 'Pettersen' 


Prog: Mohamed Youssef 1۹۷ E_Mail: Mohamed.yoyo@gmail.com 


النتیجہ :إا ں‌یمA‏ 


LastName FirstName Address City 
Pettersen Kari Storgt 20 Stavanger 
Svendson Tove Borgvn 23 Sandnes 


تستخدم نفس الطريقه مع الأرقام والتواريخ مع مراعاه 
ان التواریخ لا تكون بين علامتي ( ') بل يستخدم (#) . 


۶ 


الاسم المستعا Alias‏ 
يستخدم في تغيير اسم الجدول أو الحقل عند عرضه نستخدمه عن طريق كلمه ۸5S‏ 


: البناء في حاله الجدول‎ 
SELECT column AS column_alias FROM table 


البناء في حاله الحقل : 
SELECT column AS column_alias FROM table‏ 
مثال : علي الجدول التالي 


This table (Persons): 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Svendson Tove Borgvn 23 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


SELECT LastName AS Family, FirstName AS Name 
FROM Persons 


Aمsںuاt: النتیجہ‎ 
نلأحظ أسماء الحقول (الأعمده)‎ 
Family Name 
Hansen Ola 
Svendson Tove 
Pettersen Kari 


SELECT LastName, FirstName 
FROM Persons AS Employees 


ARمsںاإ†: النتیجھ‎ 
ان اسم الجدول‎ ظحألناabاe‎ Employees: 
LastName FirstName 
Hansen Ola 
Svendson Tove 
Pettersen Kari 


Prog: Mohamed Youssef ۱۹۸ E_Mail: Mohamed.yoyo@gmail.com 


الربطٌ ١١0ل‏ 


موضوع من اهم مواضيع ا50 هو الربط بين الجدأول الذي يسهل كثير في عرض البيانات من الجدأول التي تحتوي علي 
علاقه مثل الموظف و القسم . 


في بعض الأحيان نحتاج إلي عرض بيانات من جدولين أو أكثر لجعل النتيجه كامله يجب انشاء علأقه . 


الربط بين الجدأو يتم عن طريق المفتاح الأساسي (ره) ره" ذء۴) الحقل الذي يكون مفتاح اساسي لأ يمكن تكرار البيانات 
بداخله . 


في الجدول التالي حقل (١_ءءرهام"ع)‏ هو حقل مفتاح اساسي الخاص بجدول الموظفين . 


اما في جدول الثاني الحقل (۲_15٠ل0۲)‏ هو حقل المفتاح الأساسي للجدول وفيه ايضا مفتاح خارجي وهو حقل 
.(Employee_ID)‏ 


الجدول الأُول:s٥ءyہاEmp‏ 


Employee_ID Name 

01 Hansen, Ola 

02 Svendson, Tove 

03 Svendson, Stephen 
04 Pettersen, Kari 


الجدول الثاني :مك0 


Prod_ID Product Employee_ID 
234 Printer 01 
657 Table 03 
865 Chair 03 


مثال : نريد ان نعرف من طلب منتج وما هو المنتج 


SELECT Employees.Name, Orders.Product 
FROM Employees, Orders 
WHERE Employees.Employee_ID=Orders.Employee_ID 


النتيجه :tإاsuمA‏ 


Name Product 
Hansen, Ola Printer 
Svendson, Stephen Table 
Svendson, Stephen Chair 


مثال : نرید ان نعرف من طلب المنتج (۲ع†ہ¡ا٥)‏ 


SELECT Employees.Name 

FROM Employees, Orders 

WHERE Employees. Employee_ID=Orders.Employee_ID 
AND Orders.Producit='Printer' 


Prog: Mohamed Youssef ۱۹۹ E_Mail: Mohamed.yoyo@gmail.com 


Resu|t: النتيجه‎ 
Name 
Hansen, Ola 


SELECT field1, field2, field3 

FROM first _ table 

INNER JOIN second table 

ON first_table.keyfield = second_table.foreign_keyfield 


مثال علي استخدIم INNER JOIN‏ : 
بناء الأجمله : 


: تنفيذ الجمله علي المثال‎ 
SELECT Employees.Name, Orders.Product 
FROM Employees 
INNER JOIN Orders 
ON Employees.Employee_ID=Orders.Employee_ID 


النتیجه :tاuںsuمA‏ 


Name Product 
Hansen, Ola Printer 
Svendson, Stephen Table 
Svendson, Stephen Chair 


تقوم الجمله ل۸ا0ل |١۸‏ بعرض جميع البيانات المشتركه بين الجدولين 
مثال علي استخدام 0۸ل L٤۴۲‏ : 


بناء الجمله ٠‏ 


تنفيذ الجمله علي المثال : 


SELECT Employees.Name, Orders.Product 

FROM Employees 

LEFT JOIN Orders 

ON Employees.Employee_ID=Orders.Employee_ID 


ەجیتنلاRەsuاt:‎ 
Name Product 
Hansen, Ola Printer 
Svendson, Tove 
Svendson, Stephen Table 
Svendson, Stephen Chair 


Pettersen, Kari 


تقوم الجمله 0۱۸ل 1٤۴۲‏ بعرض جميع البيانات من الجدول 
الأول ممردام"ع حتي لو لم توجد في الجدول الثاني 


: RIGHT JOIN مIدختسأ مثال علي‎ 


بناء الجمله ٠‏ 


Prog: Mohamed Youssef ۹۰ E_Mail: Mohamed.yoyo@gmail.com 


SELECT field1, field2, field3 

FROM first _ table 

RIGHT JOIN second table 

ON first_table.keyfield = second_table.foreign_keyfield 


: تنفيد الجمله علي المثال‎ 
SELECT Employees.Name, Orders.Product 
FROM Employees 
RIGHT JOIN Orders 
ON Employees.Employee ID=Orders.Employee_ID 


النتیجه :tاuںsمA‏ 


Name Product 
Hansen, Ola Printer 
Svendson, Stephen Table 
Svendson, Stephen Chair 


تقوم الجمله 1۸١0ل ۴|6١١‏ بعرض جميع البيانات من الجدول الثاني 0۲٠۲s‏ حتي لوتةجد في الجدول الأول 
مثال علي أستخدام جمله INNER JO|N‏ : 
نريد عرض اسماء الموظفين الذن طلبوا المنتج (ماہا٥)‏ 


SELECT Employees.Name 

FROM Employees 

INNER JOIN Orders 

ON Employees.Employee ID=Orders.Employee_ID 
WHERE Orders.Product = 'Printer' 


ەجیتنلاResuاt:‎ 


Name 
Hansen, Ola 


حدول يوضح الفرق بين انواع الربط فى لغة الأستعلامات :-' 


المملاه الفانية من الجحول الأيمر_ | الميله الفاتبة من البحول اليس 


۴ل | السجلات المتعلقة بالجدول الأيمن فقط السجلات المتعلقة بالجدول الأيسر فقط 


LEFT‏ جميع السجلات السجلات المتعلقة بالجدول الأيسر فقط 
RIGHT‏ السجلات المتعلقة بالجدول الآيمن فقط 


وبهذا نکون انتهینا من شرح جمله 01۸ل . 


أ - د.م/ سمير محمد المكاوي : قاعدة البيانات )١(‏ SئكمععA‏ ءبورسعيد » المعهد العالى للحاسب الألي › لعام ۰۰٤‏ ۰ ص۹۲٩‏ 


Prog: Mohamed Youssef ۲۰١ E_Mail: Mohamed.yoyo@gmail.com 


UNION and UNION ALL gaأl‎ 


تستخدم لدمج حقلين من جدولين مختلفين ولكن يجب ان يكون نوع البيانات في الحقلين واحد اي يكون نصوص أو ارقام 


إلخ 


sm mE 


البناء للجمله يكون كالتالي : 


نرید دمج الحقل ۸۷01۴ ع في كل من الجدولين : 


نلأحظ ان النتيجه ظهرت بدون تكرار للبيانات . 
أستخدام UNION ALL‏ : 


Employees Norway: 


E_ID E _ Name 

01 Hansen, Ola 

02 Svendson, Tove 

03 Svendson, Stephen 
04 Pettersen, Kari 


Employees USA: 


E_ID E Name 

01 Turner, Sally 

02 Kent, Clark 

03 Svendson, Stephen 
04 Scott, Stephen 


SELECT E_Name FROM Employees _ Norway 
UNION 
SELECT E_Name FROM Employees USA 


النتیجہ :tاںومR‏ 


E Name 

Hansen, Ola 
Svendson, Tove 
Svendson, Stephen 
Pettersen, Kari 
Turner, Sally 

Kent, Clark 

Scott, Stephen 


مثل أستخدام N١0|ل١ل‏ الفرق انه يقوم بعرض جميع البيانات حتي لو يوجد تكرار . 


البناء للجمله يكون كالتالي : 


E_Mail: Mohamed.yoyo@gmail.com 


Prog: Mohamed Youssef 


مثال : نرید دمج الحقل N۸1۴۳‏ _ع في الجدولين السابقين 


SELECT E_ Name FROM Employees _ Norway 
UNION ALL 
SELECT E_ Name FROM Employees_USA 


النتیجه i:‏ إا ںیم 
E Name‏ 
Hansen, Ola‏ 


Svendson, Tove 
Svendson, Stephen 
Pettersen, Kari 
Turner, Sally 

Kent, Clark 
Svendson, Stephen 
Scott, Stephen 


نلأحظ ظهور جميع البيانات مع تكرار احد الأسماء المشترك في الجدولين . 
(الأن ننتقل إلي درس مهم جدا في لغه ا50 الأ وهو الدوال) 


SQL Functions JIgدأil‎ 


لغه 561 بها الكثير من الدوال العددية والحسابية 


البناء الأساسي لأي داله : 


الدوال : 


الداله 
AVG(column)‏ 
COUNT (column)‏ 
COUNT()‏ 
First(column)‏ 
last(column)‏ 
Max(column)‏ 
Min(column)‏ 
SUM(column)‏ 
COUNT (DISTINCT column)‏ 


E_Mail: Mohamed.yoyo@gmail.com 


SELECT function(column) FROM table 


الوصف 
لأيجاد الوسط الحسابي للحقل المحدد 

معرفه عدد الصفوف(السجلات) في الحقل بدون السجلات الفارغه 

معرفه عدد الصفوف في الجدول 

معرفه قيمه أول سجل في الحقل 

معرفه قيمه أخر سجل في الحقل 

معرفه أكبر قيمه سجل في الحقل 

معرفه أضغر قيمه سحل في الحقل 
معرفه إجمإلي القيم في الحقل 

SERVER‏ ا5Qعدد‏ السجلات في الحقل بدون تكرار تعمل فقط علي 
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مجموعه من الامثله : 


SELECT AVG(Column) From Table 

SELECT COUNT(column) From Table 

SELECT COUNT() From Table 

SELECT First(column) From Table 

SELECT last(column) From Table 

SELECT Max(column) From Table 

SELECT Min(column) From Table 

SELECT SUM(column) From Table 

SELECT COUNT(DISTINCT column) From Table 


SQL GROUP BY and HAVING jرفlly التجميع‎ 


الدوال العدديه متثل الداله 500 كثيرا ما تحتاج إلي التجaمیg GROUP BY‏ 


٠ بناء الجمله‎ 
SELECT column,SUM(column) FROM table GROUP BY column 


مثال للتوضيح : علي الجدول التالي 


Company Amount 
W3Schools 5500 
IBM 4500 
W3Schools 7100 


ننفذ الجمله التاليه: 
SELECT Company, SUM(Amount) FROM Sales‏ 


Returns this result: 4جيتiأl‎ 


Company SUM(Amount) 
W3Schools 17100 
IBM 17100 
W3Schools 17100 


نلأحظ ان جميع السجلات اخذت المجموع كله ولم نعرف مجموع كل سجل . 
الأن نجرب جمله الأستعلام بعد إضافه إ8 GRO U٣‏ : 


SELECT Company,SUM(Amount) FROM Sales 
GROUP BY Company 


Returns this result: 4جيتiأl‎ 


Company SUM(Amount) 
W3Schools 12600 
IBM 4500 


نلأحظ انه تم جمع كل سجل وحده وأصبحت النتيجه أوضح 
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الداله 1۸۷16 تستخدم لفرز البيانات حسب شرط معين 
بناء الجمله ٠‏ 


تطبيق علي نفس المثال السابق : 


Company Amount 
W3Schools 5500 
IBM 4500 
W3Schools 7100 


ننفذ جمله الأستعلام التاليه : 


SELECT Company,SUM(Amount) FROM Sales 
GROUP BY Company 
HAVING SUM(Amount)> 10000 


Returns this result : 4جيتiأl‎ 


Company SUM(Amount) 
W3Schools 12600 


نلأحظ انه تم تحقق الشرط وعرض البيانات اكبر من ٠٠٠٠٠١‏ فقط. 


Prog: Mohamed Youssef ۲.٥ E_Mail: Mohamed.yoyo@gmail.com 


Data Definition Language (DDL) ڍ‎ "ilil الجر ۽ الثالث '"'تعريف‎ 


في هذا الجزء من الدرس سوف نقوم بشرح 


Data Definition Language (DDL) 
هو القسم المسئول عن : تعريف البيانات‎ 


Create Database - `‏ : لأنشاء قاعده بيانات جديدة 
- eاrab Create‏ : لأنشاء جدول داخل قاعدہ بیانات 
۸L٣ ER ABLE -۳‏ : للتعديل في الجدول 

؟؛- D۴0P r ABLE‏ : لحذف الجدول من قاعدہ البیانات 
CREATE INDEX -ٌ°‏ : لأنشاء مفتاح للبحث (الفھارس) 
DROP |NDEX -“‏ : لحذف مفتاح البحث 


: Create Database ٽlilyڊ‎ oدعاق ولا انشاء‎ 


بناء الجمله كالتالي 


طبعا نحدد اسم قاعده البيانات 
قاعده البيانات ديه هتكون خالية. 


لأنشاء جدول داخل قاعده البيانات ماطa]‏ eم†Crea:‏ 


يكون بناء الجمله كالتالي : 


مثال علي أنشاء جدول : 


CREATE TABLE Person 
( 

LastName text(30), 
FirstName text(30), 
Address text(150), 

Age (Number) 

) 


الأن يمكننا انشاء جدأول وتحديد الحقول وانواع وحجم البيانات فيها . 
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" CREATE INDEX انشاء اأ‎ 


الفهرس يصمم في الجدول حتي يجعل عمليه الأستعلام أسرع كما يمكن انشاء اكثر من فهرس نفس الجدول 
المستخدم لأ يري هذه الفهارس انما هي لتسرع عمليه الأستعلام فقط . 


هناك نوعين من الفهارس النوع الأول لأ يمكن ان يتكرر به البيانات اما النوةاع الثاني يمكن تكرار البيانات به . 


البناء للفهرس من النوع الفريد (الذي لا یتکرر) ×ملہ! i»ueہ U‏ 


البناء للفهرس من النوع العادي >مل! ماSimp‏ 


CREATE INDEX PersonlIndex 
ON Person (LastName) 


لأنشاء فهرس بترتيب عكسي : 


CREATE INDEX PersonlIndex 
ON Person (LastName DESC) 


لأنشاء فهرس في حقلين في نفس الجدول : 


CREATE INDEX Personlndex 
ON Person (LastName, FirstName) 


۶ 


لامر مہا5 


Drop‏ ترجمتها الحرفيه إلقاء ولكننا هنا نستخدمها كأمر حذف ولكن حذف ايه ( قاعده بیانات - فهرس - جدول) 
أولاً: - حذف قاعد بيانات : يكون بناء الجمله كالتالي 

ثانيا :- حذف جدول من قاعده البيانات : يكون بناء الجمله كالتالي : 

ثالثا :- حذف فهرس : ويختلف البناء حسب نوع قاعده البيانات 


مثال : 


Syntax for Microsoft SQLJet (and Microsoft Access): تIنlيبئl نوع قاعده‎ 
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Syntax for MS SQL Server: ٽilgبll نوع اعد‎ 
Syntax for IBM DB2 and Oracle: ٽنlgبll‎ oدعاق نوع‎ 
Syntax for MySQL: تIنlıبl نوع قاعد‎ 


أخير امر حذف البيانات من داخل الجدول دون حذف الجدول : 


ALTER TABLE ja 


يستخدم في التعديل علي الجدول من إضافه وحذف أعمده (حقول) . 


لأضافه حقل : يكون بناء الجمله كالتالي 


لحذف حقل : يكون بناء الجمله كالتالي : 


مثال : علي الجدول التالي 


Person: 


LastName FirstName Address 
Pettersen Kari Storgt 20 


: لأضافه حقل جديد‎ 
To add a column named "City" in the "Person"' table: 
ALTER TABLE Person ADD City varchar(30) 


النتیجه :tاںومR‏ 


LastName FirstName Address City 
Pettersen Kari Storgt 20 


لحذف حقل من الجدول : 


To drop the "Address" column in the "Person" table: 
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ALTER TABLE Person DROP COLUMN Address 


Rمsuاإا{: النتيجه‎ 
LastName FirstName City 
Pettersen Kari 


SELECT INTO جمذأ4‎ 


تستخدم عاده في حفظ نسخه أحتياطيه من الجدول 
بناء الجمل كالتالي : 
SELECT column_name(s) INTO newtable [IN externaldatabase]‏ 
FROM source‏ 
لعمل نسخه إحتياطيه من الجدول في نفس القاعده : 


SELECT *INTO Persons _ backup 
FROM Persons 


لنسخ الجدول لقاعده بيانات أخري : نستخدم |١‏ 


SELECT Persons.* INTO Persons IN 'Backup.mdb' 
FROM Persons 


يمكن أيضا نسخ حقول محدده فقط: 


SELECT LastName,FirstName INTO Persons _ backup 
FROM Persons 


نفس المثال السابق ولكن مع إدخال شرط : ٥۲ما۷‏ 


SELECT LastName,Firstname INTO Persons _ backup 
FROM Persons 
WHERE City='Sandnes' 


إذا اردنا نسخ الجدول لكن في وجود علأق مع جدول أخر : 


SELECT Employees.Name,Orders.Product 

INTO Empl_Ord backup 

FROM Employees 

INNER JOIN Orders 

ON Employees.Employee ID=Orders.Employee_ID 


CREATE VIEW 4ذaج‎ 


تستخدم لأنشاء جمله تعرض بيانات تحت شرط معين 
يمكن أستخدام اي من جمل 501 بها مثل عمل علأقه 
أو إضافه داله من الدوال . 
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يكون بنانها العام كالتالي : 


CREATE VIEW view _ name AS 
SELECT column_name(s) 
FROM table name 

WHERE condition 


۶ ملأحظات هامه ٠‏ 
١‏ قاعده البيانات لأ تتأثر بما يتم تنفيذه من شروط أو دوال 
۲ قاعده البيانات لأ تقوم بحفظ الناتج في جدول وانما يقوم محرك قاعده البيانات بتنفيذ الجمله كل مره تقوم بتشغيله فيها 
بعض الامثله المبنيه علي قاعده البيانات Northwind‏ : 
مثال ۱ ۰ 
CREATE VIEW [Current Product List] AS‏ 
SELECT ProductlD,ProductName‏ 


FROM Products 
WHERE Discontinued=No 


كيف يتم تشغيله : عن طريق الجمله الأتيه 
SELECT * FROM [Current Product List]‏ 
مثال ۲ : 
CREATE VIEW [Products Above Average Price] AS‏ 
SELECT ProductName,UnitPrice‏ 


FROM Products 
WHERE UnitPrice>(SELECT AVG(UnitPrice) FROM Products) 


يتم عرضه بالجمله. 
SELECT * FROM [Products Above Average Price]‏ 
مثال ۳ : 
CREATE VIEW [Category Sales For 1997] AS‏ 
SELECT DISTINCT CategoryName,Sum(ProductSales) AS CategorySales‏ 


FROM [Product Sales for 1997] 
GROUP BY CategoryName 


SELECT * FROM [Category Sales For 1997]‏ 
ويمكن أستخدام الشرط اثناء عرض البيانات : 


SELECT * FROM [Category Sales For 1997] 
WHERE CategoryName='Beverages' 


تم بحمد الله 
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مراحح الملحق ا ول (أوامر ا 54) : 
کح 00۸5 8B‏ 


-١‏ سلسلة تعلم بسهولة < Oracle‏ معلومات أساسية و قواعد اللغة › ۾/ عڪزب محمد عزب. 

۲ ملخص أاوامر ماcھ0 ۴٥۲‏ usاP‏ ٭54۵1 ۰ د/ صالح زرمبھ۔ 

۳- كيفية إنشاء قاعدة بیانات م|اOrac‏ لشركة أدوية »> د صالح زرمبه. 

؛- ملخص ء۸ ٠ا†ءم5‏ قواعد البيانات (۲) لبرنامج 2000 ۲٠۲۷م‏ ا51 ٠»‏ أ/ عبد الرحمن سالم. 


الكت الألكترونبث 0۴ ° 


-١‏ موقع الفريق العربي للبرمجة › المرجع الشامل في جمل 51 › قام بالنقل والترجمة أحمد حامد. 
- موقع الفريق العربي للبرمجة › بناء التطبيقات قواعد البيانات العملاقة › أ/ خضر يوسف ترزي. 
۳- موقع الفريق العربي للبرمجة › مرجع الأوامر ام۷إمS‏ اSQ-ء‏ › م/ أحمد كمال. 

-٤‏ موقع كتب الحاسب العربية › تعلم هرام ا501 (الجزء الأول) » أ/ محمود محمد عبد الرازق. 
-٥‏ الأساسيات في قواعد البيانات مودطهاه ٠‏ أ/ مجلاد مشاري السبعي. 

.NaaS7 ac) الكاتب‎ ٠ دليل تعلم ال اه5 للمبتدئين‎ -١ 

۷- مقدمة قواعد البيانات باستخدام ا54 › م/ إبراهيم درويش. 


مواقع الإننرنت 5ا5 اع ۷ 
تم زيارة المواقع في الفترة من ۲۰۰۸/۷/۱۰ إل ۲٠۰١۰۸/۱۲/۱۳‏ 


1- http ://www.kutub.info/library/list.php 2cat=17 

2- http ://www.arabteam2000-forum.com/index.php?showtopic=159394 

3- hittp://www.arabteam2000-forum.com/index.php?showtopic=87202 

4- hittp://www.vb4arab.com/vb/forumdisplay.php?=34 

5- http ://www.arabmoheet.net/forum/default.asp?codepagqe=2&forum no=16 

6- http://www.tartoos.com/HomePage/Rtable/ComputerSchool/Proqramminq/proqram6.htm 
7- http://www.swalif.net/softs/swalif59/softs197329/ 

8- http://vb.vip600.com/showthread.php ?i=214611 

9- http ://www.hiarab.net/article5880. html 

10- hittp://www.boosla.com/showArticle.php?Sec=DB&id=23 

11- hittp://forum.mans-fci.net/viewtopic.php?2f=33&i=7680&starlt=0&st=0&sk=t&sd=a 


12- http://www.prameq.com/vb/showthread.php?i=37742 


V1deos:- 


13- http ://www.freelearn.110mb.com/sqI2000/tutorials.htiml 
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Visual Basic.Net 2005 


قا موس مصطلدان L0SS4§Y‏ 6 


مصطلحاث : لغخ البیریف اطی دوخ نخ 


المعنيي أو الوظيوة 


تنشبط الكائن (حدث لبعض الكائنات) 


محاذاة (خاصية لبعض الكائنات) 

محاذاة إلي الوسط أو التوسيط (خاصية لبعض الكائنات) 
محاذاة الكتابة إلي إليسار (خاصية لبعض الكائنات) 
محاذاة الكتابة إلي إليمين (خاصية لبعض الكائنات) 


التحكم فى صورة الخلفية للنموذج (خاصية للنمودج) 
كود التعليمات الرمزية لجميع آغراض المبتدئين وهو اختصار 

Beginner's All purpose Symbolic Instruction Code 
منطقي (نوع البيان)‎ 


تغيير في الكائن (خاصية لبعض الكائنات) 

معرفة أو تحديد ما إذا كانت الأداة ستتدخل في تعديل الحروف 
صندوق اختبار (أداة من صندوق الأدوات) 

دالة تستخدم في الحصول على الحرف أو الرمز المناظر لكود معين 
رسم دائرة (وسيلة للنموذج › كود برمجي) 

لتصنيف أو الفئة 


کے 
« 
hn‏ 
« 
٩‏ 

3 
« 
% 
| 
« 

٩ 
n 
« 
« 
« 
3 
« کے‎ 


مسح الكتابة والرسم من داخل الكائن (كود برمجي) 
نافذة الأكواد البرمجة 

الفاصلة ),( 

زر أوامر (أداة من صدوق الأادوات) 

المعاملات المقارنة 


المعاملات الربط 


» 
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Visual Basic.N et 2005 


Activate 
Add Form 
Add Project 
ADO .NET 


Alignment - Center 
Alignment - Left 
Alignment - Right 
Apostrophe 
Applications 


Arithmetic Expressions 
Arithmetic Operator 
Arith metical 

Array 


Asc ( ) 


Back Color 
Back Style 
BackGroundlmage 


BASIC 


Basic Concepts 
Boolean 

Border Style 

Break 

Byte 

Change 
CharacterCasing 
Check Box 

Chr ( ) 

Circle 

Classes 

Click 

CLS 

Code Window 
Comma 

Command Button 
Comparison Operator 
Compiler 

Computer Languages 
Concatenation - String 
Concatenation Operator 
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المعني أو الوظيةة 
الشرط Condition‏ 
Conditional Branching‏ 


ب ب ۲ ) Const ( Constant‏ 
صندوق تحكم » صندوق الأدوات Control Box‏ 


CSir( ) 


Current X 
Current Y 
Customize 
Data Type 


DB Click TTT ET 
( Double Click) نقر مزدوج بالزر الأيسر للفارة (حدث)‎ 


Defined Functions 
Definition 
Design Modê 
Dim (Dimension) إعلان » تعريف المخزن المتغير أو المصفوفة (كود برمجي)‎ 


سمك خط الرسم داخل الكائن (خاصية لبعض الكائنات) Draw Width‏ 


تحریر (قائمة في شريط القوائم) 

Encapsulatior 
إغلاق أو إنهاء البرنامج (كود برمجي)‎ 
إنهاء الإجراء (كود برمجي)‎ 


النسخة المشروعات لبرنامج البيزيك المرئي 


Enterprise Edition 


حدث (يقع علي کائن ويتاثر به) Event‏ 


Event Driven Programs البرامج الموجهة بالأحداث‎ 


الاستجابة للأحداث التي تقع عليه Event Driven‏ 


Event Handler معالج الأحداث‎ 


EXE File 


ملف (قائمة في شريط القوائم) 

لون تظليل الرسومات أو لون التعبئة (خاصية لبعض الكائنات) 

نمط تظليل الرسومات أو لون التعبئة (خاصية لبعض الكائنات) 

دالة تستخدم في الحصول على الجزء الصحيح الموجود في عدد حقيقي معين 
خط الكتابة (خاصية لبعض الكائنات) 

حلقة تكرارية (كود برمجي) 


لون الأمامية › لون خط الكتابة (خاصية لبعض الكائنات) 


Fill Color 
Fill Style 
Fix () 


Fore Color 


نموذج (الكائن الرئيسي في البيزيك المرئي) 
Form Layout Window‏ 
Form Window‏ 
نافذة النموذج عند حافة الشاشة العليا (خاصية للنموذج) 
FormBorderStyle‏ 

ه - للحصول على النتيجة قد تكون (حرفية › عددية ( 


Form1.Top 


e 
Hardware 


اللغة عاليةالمستوى (لغة يفهمها الإنسان) High Level Language‏ 


شريط التمرير الأفقي (أداة من صندوق الأادوات) 


Prog: Mohamed Youssef 1٤ E_Mail: Mohamed.yoyo@gmail.com 


المعنبي أو الوظيفة 


أكبر تغيير في شريط التمرير الافقى 
(خاصية لشريط التمرير) 


HScrollbar -LargeChange 


أقل تغيير في شريط التمرير الافقى 

(خاصية لشريط التمرير) 

رمز أو أيقونة (خاصية للنموذج) 

أداة رسم (أداة من صندوق الأدوات) PictureBoX‏ 

أضافة صورة الى كائن (خاصية للنموذج) 

دالة تعرض رسالة داخل صندوق حوار» تم ينتظر من المستخدم إدخال نص أو 

النقر على أي زر من أزرار صندوق الحوار. 

دالة تستخدم للحصول على مكان حرف أو مكان كلمة مطلوب البحث عنها داخل 
أستشعار ذكي (هى القائمة التى تظهر عند كتابة الكود) IntelliSense list‏ 
Interpreter‏ 


Interval 


HScrollbar -SmallChange 


eon o o o | 


InputBoX ( ) 


Instr ( ) 


فترة زمنية مستغرقة (تفاوت على فترات › خاصية لميقاتي) 
أداة العنوان (أداة من صندوق الأدوات) Label Control‏ 
ا 


دالة تستخدم لتحويل الحروف الإنجليزية الكبيرة إلي الصغيرة ) ( LCase‏ 
Left‏ 
دال تستخدم في الحصول على طول أي سلسلة حرفية )( Len‏ 
Limited looping‏ 
Line‏ 
Load‏ 
Logic - logical‏ 
Logical Operator‏ 


عدد صحيح طويل (نوع البيان) Long‏ 
Long Integer‏ 


اللغة المتدنية - منخفضة - المستوى (لغة يفهمها الكمبيوتر) Low Level Language‏ 


Main Window 
MaxButton زر تكبير النافذة (من خصائص النموذج)‎ 


Multiple Document Interface Form 
Menu Bar شريط القوائم‎ 
MessageBox.Show داله عرض الرسائل الثابته بأاى طرق‎ 
دالة تستخدم للحصول على جزء من سلسلة حرفية معينة بدءا من حرف معين‎ 
داخل هذه السلسلة.‎ 
زر تصعير النافذة (من خصائص النموذج)‎ 
وحدة نمطية (جزء البرمجة)‎ 
زر الفارة للضغط عليه (حدث لبعض الكائنات)‎ 
حركة زر الفارة (حدث لبعض الكائنات)‎ 
ترك زر الفارة عند الضغط عليه (حدث لبعض الكائنات)‎ 
MsgBox ( ) دالة تعرض رسالة في صندوق حوار‎ 


الكتابة داخل صندوق النصوص في عدة اسطر (خاصية للنص) MultiLine‏ 


Mid ( ) 


Mouse Down 
Mouse Move 


الوسائط المتعددة 
التفرع المتعدد Multiple Branching‏ 
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المعنيي أو الوظيوة 


الاسم البرمجي للكائن (خاصية في جميع الكائنات ) 
مجالات الأسماء Name Space‏ 
New Project‏ 


القيمة الجديدة التي يتم إضافتها للخواص New Value‏ 


Object Behavior 


Object Name اسم الكائن‎ 


Object Oriented Programming البرمجة الموجهة بالأحداث‎ 


Open Project 
Operator 


Procedure 
Professional Edition 
Project Explorer Window 
Project Window 
Properties Window 
Puse Button ضغط الزر (من لوحة المفاتيح › الفارة)‎ 
Radio Button 
Randomize 
ReadOnly 


Replace ( ) 


Reserved Functions 
RightToLeft 


دالة تستخدم في توليد عدد حقيقي عشوائي قيمته أكبر من أو تساوي الصفر وأقل 


من الواحد الصحيح. 


Rnd ( ) 


Run Mode 
Save Form 
Save Project 
Scale Height عدد الوحدات الراسية للكائن و هي المستخدمة مع الرسومات‎ 
Scale Mode نمط وحدة القياس في الكائن (خاصية للنموذج)‎ 
Scale Width عدد الوحدات الأفقية للكائن و هي المستخدمة مع الرسومات‎ 
e 
e 
SDLC دورة حياة تطوير النظام‎ 
System Development Life Cycle 

Select a control 
Semi Colon 
ET 
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المعذي أو )لو ظيوة 
أحادى الدقة Single Precision‏ 
نمط عرض الصورة فى الكائن (خاصية لصندوق الصور) Size Mode‏ 
خطوط الزرقاء التى تظهر عند ضبط المجاذاة الكائنات Snap Lines‏ 


الأوامر الجاهزة فى الفيجوال بيسك ٠٠٠٠١‏ 
لبرمجيات 


اة الكل 


Solution Explorer نافذة الحل‎ 
Source Program البرنامج المصدر‎ 
Special Symbols لرموز الخاصة‎ 
لغة الاستعلامات الهيكلية‎ 
SQL 
Structured Query Language 


3 


E 
البرمجية‎ 
تحجيم الصورة الموجودة داخل صندوق الرسم‎ 


قياسي 


Stander Edition 


e 


لتعبيرات النصيه String Expressions‏ 
البرمجة الهيكلية Structured Programming‏ 
بداية الإجراء 
Symbol‏ 
Text Box Control‏ 
صندوق النص (أداة من صندوق الأدوات) TextBox‏ 
خاصية الكتابة داخل صندوق النص TextBox - Text‏ 
دالة تستخدم فى الحصول على الوقت فى إليوم ) ( TimeOfDay‏ 
توقيت - الميقاتي (أداة من صندوق الأدوات) Timer‏ 
شريط العنوان Title Bar‏ 
شريط الأدوات Toolbar‏ 
Toolbox‏ 
أدوات (قائمة في شريط القوائم) Tools‏ 
لتفادى الاخطاء المنطقية والبرمجية فى البرنامج (قنص الاخطاء) ...... Try ..... Catch‏ 
دالة تستخدم لتحويل الحروف الإنجليزية الصغيرة إلي الكبيرة ) ( UCase‏ 
التفرع الغير المشروط Unconditional Branching‏ 
واجهة المستخدم User Interface‏ 
شريط التمرير رأسي V.ScrollBar‏ 
دالة تستخدم في الحصول على القيمة العددية لسلسلة حرفية معينة أو متغير حرفي )( Val‏ 
قيمة (خاصية لبعض الكائنات) Value‏ 
متغیر Variable‏ 
عرض (قائمة في شريط القوائم من خلالها إظهار النوافذ) View‏ 
ظهور الكائن أو إخفاؤه (خاصية لبعض الكائنات) Visible‏ 
Visual Basic‏ 
حزمة البرامج التى تحتوى على برنامج البيزيك المرئى Visual Studio.Net‏ 
Width‏ 
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أداة صندوق النص 


التو 


صندوق أدوات 


| 
ف 


عرض (خاصية لبعض الكائنات لقياس أو لضبط عرضها) 


Working Area 
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Refer€e^C€S gجlرkl‎ 


8 00KS كىج‎ 


۱ - د/ جمال عبد العظيم: مقدمة في البرمجة الهيكلية باستخدام Basic‏ اVisua‏ »› جامعة قناة السويس ٠‏ كلية الهندسة. 
ا أحمد فهمي محروس: مقدمة البرمجة باستخدام 2005 Visual Basic.Net‏ › ماlدة‏ الكمبيوتر - الصف الثالتث 
الأعدادي › للعام الدراسي 0۹/۰۰ 

کا سور ان ھر روق ,ر خا السعدني: دليل الطالب لمادة الكمبيوتر وتكنولوجيا المعلومات › الصف الأول الثانوي العام 
للعام الدراسي .٠٠٠۹/۲۰۰۸‏ 

٤دا‏ محمد اأحمد ويفا برمجة المشاريع المستخدمة في المنهج "الفيجوال بيسك دوت نت "٠٠‏ الصف الأول 


الثانوى العام - الجزء الخاص بلتعلم الألكتروني ٠‏ للعام الدراسي .٠٠٠۰۹/۲۰۰۸‏ 


کت اطنر مخ )800 


١ 


تأليف مايكل هالفرسون » ترجمة مركز التعريب والبرمجة بدار العربية للعلوم : الفيجوال بيسك دوت نت ۲٠٠٠١‏ 
4 خطوة بخطوة " › الطبعة الأولي .٠٠٠٠‏ 


الكت الألکترونية €×€ ,0۴ ۴ 


١ 


- ١ 
-۱١ 


-۲ 
-۳ 
- ٤ 


° 
-۱٦ 
-۷ 
-۸ 
-۹ 
۰ 
-۲١ 
-۲ 
-۳ 
- <٤ 
° 


-۲ ٦ 


إعداد فريق عمل موقع فيجوال بيسك للعرب: مجلة موقع الفيجوال بيسك للعرب »> العدد الأول يناير ۹۰۸ 

تأليف ‘Visual Lover‏ طريقة تصميم أله الحاسبة باستخدام VB.Net‏ « موقع كتب الحاسب العربية. 

أ/ حسن عثمان قحوم: تعلم لغة اوج6 اهںوءا۷ للمبتدئين والمتوسطين › موقع كتب الحاسب العربية. 

م/ سامح سنوسي: كيفية التعامل مع مكتبة (08ا0) ۸00 » موقع كتب الحاسب العربية. 

بواسطة مووںهمY‏ : دورة كاملة في ۸50.۸61 » منتدي عرب ناو. 

بواسطة وج٥‏ : أحدث التطبيقات لبرنامج الفيجوال بيسك دوت نت ١ Eves ۰۰١‏ ٥icatiاAppl‏ › منتدي 
عرب ناو. 

إعداد فريق أعضاء المنتدي: في رحاب )امس مصه۴۲ 6. › منتدي فيجوال بيسك للعرب. 

الكاتب المخلب الجارح: دورة تعليم الفيجوال بيسك دوت نت ۲٠٠٠١‏ " بأسهل الطرق " ٠‏ منتدى فيجوال بيسك. 
الكاتب الامبراطور 71<×: تحزیم برامج الفيجوال ستيديو ٠٠٠٠١‏ عمل ال Setup‏ »› منتدي العاصفة. 

أ/ علاء جمعه: تعقب وتصحيح الأخطاء في الدوت نت > منتدي المحيط العربي 

تألیف م/ شاکر > تجميع فريق بيوكوم للتكنولوجيا: مدخل إلڵي ۷8.Ne‏ الموسوعة العربية للكمبيوتر والإنترنت › 
قشنم الذرر ات التعلمية > سلسة كنت الدررات العامة الالكتروفة 

م/ تركي العسيري: برمجة أطار عمل بإستخدام .اوج8 امuوءا۷‏ » الطبعة الاولي .۲٠٠۳‏ 

أ/ عبد الرحمن .. أ/ فهمي ياسين:التعامل مع الصور والرسم › منتدي الفريق العربي للبرمجة. 

م/ إحسان مزهر رشيد: ملخصات في 2003 .اج8 امںوءا۷ (۲) » المركز العالي للمهن الشاملة درنة › قسم 
الحاسوب ¢ ©0 

أ/ محمد الفرح: كيفية عمل برنامج قارئ الكتب الكترونية 9۴م › منتديات كتاب العرب . 

م/ محمد علي كنيفو: تعلم الفيجوال بيسك دوت نت ٠٠٠٠١‏ » الأصدارة الأولي. 

م/ محمد علي كنيفو: تعلم الفيجوال بيسك دوت نت ٠ ۲٠٠٠١‏ الأصدارة الثانية. 

أ.م/ محمد الحاج: محاضرات مادة 2005 ۷8.۸61 ( نظري - عملي ). 

أ/ غدير سهيل محمد" | عداد الفيجوال ستيديو ۰0 

أ/ محمود صقر: مدخل إِلئي 2005 .Visual Basic.Net‏ 

تأليف آندروفوس > ترجمة م/ محمد علي يوسف: مقدمة في الفيجوال بيسك دوت نت 00 الطبعة الأولي ۰۹٦‏ 
الكاتب غير معروف: كيفية تحزيم برامج 2005 م8.۸/. 

تأليف :Anmed Haar‏ أنشاء قاعدة بيانات 501 ببرنامج 2005 ./8.N6†‏ 

تأليف وأوومر"۸ه۴: تحزيم البرامج بالفيجوال بيسك .٠٠٠٠١‏ 

م/ محمد عبد الناصر خطيب: الوجيز فی الجديد » أستثمر اللغة بكل طاقتها 2005 Basic.‏ اجVisu‏ › الطبعة 
SS‏ 

.Programming with VB.Net :Jıl م/ محمد جودة‎ 
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۷- م/ محمد الشهري: دورة الفيجوال بيسك دوت نت الشاملة " مها؟ ر6 مه5 " ٠‏ الجزء الأول. 
۸- م/ محمد حمدي غانم: من الصفر إلي الأحتراف ام١.۷8.‏ 

۹- الكاتب غير معروف: تعلم إنشاء قاعدة البيانات 2005 S6۲‏ اSQ.‏ 

١‏ ط/ عمار الترك: مقدمة عامة للغات البرمجة. 
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17- http://www.uae4ever.com/vb1/Emara9/thread106738.html , viewed 06/11/2008 
18- http ://www.arabs2day.ws/forums/index.php?showforum=32 , viewed 06/03/2009 
19- http://www.absba.org/showthread.php ?i=668464 ,viewed 20/11/2008 
20- http ://www.ibtesama.com/vb/showthread-t 10204.html ,viewed 20/11/2008 
21- http://www.bramjnet.com/vb3/showthread.php?ti=150370 ,viewed 20/11/2008 
22- http ://www.star28.com/book/b7.html ,viewed 10/12/2008 
23- http ://vb.vip600.com/showthread.php?i=71427 ,viewed 11/12/2008 
24- http ://www.ask-pc.com/vbx/showthread.php?i=11489 ,viewed 11/12/2008 
25- http://www.elaana.com/vb/f11-2 ,viewed 11/03/2009 
26- http://www.hayatech.com/c/showthread.php 214725 , viewed 11/03/2009 
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28- http://vb.ihsac.com/t355/ ,viewed 11/03/2009 
Videos:- 
29- http://www.kutub.info/library/list.php?cat=75 ,viewed 20/10/2008 
30- http://www.youtube.com/watch?v=qm7lmpkPKF4 , viewed 25/06/2008 


31- http://www. freelearn.110mb.com/visualbasic/level1/tutorials.html ,viewed 20/11/2008 
32- http://www. treelearn.110mb.com/visualbasic/level2/tutorials.html ,viewed 20/11/2008 
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@ pion 


initia TIVE 


ے ااا 
تم تصميم هذا الكتاب لتعلم البرمجة › النقطة الهامة هناك أن العديد من الكتب تركز 
على تعليم مبادئ البرنامج بطريقة جامدة . 


وبالتالي يصعب تعلم البرمجة. 


ولذلك فاإننا نعتقد أن تبنى هذا الأتجاة من الأهمية بمكان حيث إن لغات البرمجة فى 
0 د » ( ولكکن قو اعد البر : تظا ثابته. 


الكتاب يقوم بشرح مبادئ البرمجة وصولا إلى برمجة قواعد البيانات. 


ويوجد ملاحق تابعة للكتاب للسهولة التعامل مع قواعد البيانات و الحصول على 
قاموس التعبيرات البرمجيه. 


وينزل هذا الكتاب إلى الواقع الحقيقى لعالم البرمجة لكثرة الأسلوب النظرى المتعمق و 
تتابع الأكواد البرمجية » شرح بالصور لجميع الأجزاء. 
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